How to replace -999 values with NaN in a Matlab table?
30 次查看(过去 30 天)
显示 更早的评论
I have a Matlab table T1, with columns like the below:
T1.year
T1.month
T1.day
T1.var1
T1.var2
...
Some of its columns are numerical and some of them are strings. For the numerical columns, there could be some -999 values in some of the columns to indicate NaN values.
Is it possible to replace all of the -999 values with NaN values, without specifying each of the columns?
I wish I could do someting as simple as that?
T1(T1==-999) = NaN
Like I do in a column data.
2 个评论
Walter Roberson
2020-10-13
Are you reading from a text file? If so then use 'TreatAsMissing', '-999' option when you do the readtable()
采纳的回答
Steven Lord
2020-10-13
Use standardizeMissing.
t = array2table(magic(4));
t{2, 'Var3'} = -999
t2 = standardizeMissing(t, -999)
更多回答(1 个)
Walter Roberson
2020-10-13
T1 = convertvars(T1, @isnumeric, @no999);
function x = no999(x)
x(x==-999) = nan;
end
另请参阅
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!