How do I use regexprep to replace final NaN values in a matrix?

4 次查看(过去 30 天)
I have a numeric data stream like this:
NaN NaN NaN 100 102 101 99 102 NaN NaN NaN NaN NaN 101 103 NaN NaN, etc
I'd like to replace the last NaN in each string of NaNs with a zero so it would look like this:
NaN NaN 0 100 102 101 99 102 NaN NaN NaN NaN 0 101 103 NaN NaN
Is this a good regexprep situation or should I do find()?

回答(2 个)

Azzi Abdelmalek
Azzi Abdelmalek 2013-3-20
A=[NaN NaN NaN 100 102 101 99 102 NaN NaN NaN NaN NaN 101 103 NaN NaN]
A(diff(isnan([A 0]))==-1)=0

Jan
Jan 2013-3-21
A = [NaN NaN NaN 100 102 101 99 102 NaN NaN NaN NaN NaN 101 103 NaN NaN];
A(strfind(isnan(A), [true, false]) = 0;

类别

Help CenterFile Exchange 中查找有关 Operators and Elementary Operations 的更多信息

标签

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by