replace nan with a value
6 ビュー (過去 30 日間)
古いコメントを表示
I have a column in which some values are missing and shown as NaN. I need to replace all these NaN with the median of the column. Here is what I tried: I am extracting column 4 in which there are missing values, find the median value, Use isnan to replace the logical 1 with the median.
Column 4 values: 1 2 3 4 5 6 NaN 12 10 NaN 4 5 NaN
C=num(:,4);
median=nanmedian(C);
R(isnan(C))=median;
But with this I am getting results as : 0 0 0 0 0 0 12 0 0 12 0 0 12
But the expected result is: 1 2 3 4 5 6 12 12 10 12 4 5 12
Any suggestions ?
0 件のコメント
採用された回答
Star Strider
2017 年 6 月 21 日
Please do not use ‘median’ as a variable name.
I don’t know where the ‘12’ value comes from, since the median of the vector you posted is 4.5.
Other than that, ‘R’ does not magickally become ‘C’. You have to create it first.
This works for me:
C = [1 2 3 4 5 6 NaN 12 10 NaN 4 5 NaN]';
median_4 = nanmedian(C);
R = C;
R(isnan(C)) = median_4;
その他の回答 (1 件)
Steven Lord
2017 年 6 月 21 日
z = [1 2 3 4 5 6 NaN 12 10 NaN 4 5 NaN].';
y = fillmissing(z, 'constant', median(z, 'omitnan'));
showBothColumnsSideBySide = [z, y]
3 件のコメント
Jan
2017 年 6 月 21 日
@Daphne: This happens, because "median" was defined as a variable on your computer. Do not shadow builtin functions by variables. Solution: Restart Matlab or:
clear median
参考
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!