Go through the table with a loop and change values
古いコメントを表示
回答 (3 件)
Subhadeep Koley
2020 年 2 月 12 日
編集済み: Subhadeep Koley
2020 年 2 月 12 日
ds = record ("xlsfile", "dataset.csv");
data = dataset2table(ds);
[rows, cols] = size(data);
newData = data;
for i = 1: rows
for j = 1: cols
if table2array(data(i, j)) == -9
newData(i, j) = array2table(NaN);
end
end
end
7 件のコメント
Megan
2020 年 2 月 12 日
Subhadeep Koley
2020 年 2 月 12 日
Megan
2020 年 2 月 12 日
Subhadeep Koley
2020 年 2 月 12 日
@Oz Can you post the dataset.csv file?
Megan
2020 年 2 月 12 日
Megan
2020 年 2 月 12 日
Subhadeep Koley
2020 年 2 月 12 日
Your "dataset.csv" is encoded with UTF-16-LE, which is not fully supported by the function readtable. Therefore, I copied and pasted all the data in a new .xlsx file (attached here).
The below code might be helpful now although it is not a very efficient solution.
clc;
data = readtable('Book1.xlsx');
[rows, cols] = size(data);
newData = data;
for i = 1: rows
for j = 1: cols
temp = table2array(data(i, j));
if iscell(temp)
temp = cell2mat(temp);
end
if temp == -9
newData(i, j) = array2table(NaN);
end
end
end
Steven Lord
2020 年 2 月 12 日
1 投票
The standardizeMissing function can accept arrays of various types, including table arrays and timetable arrays. If you only want to standardize the form in which missing data is stored for certain variables in your table you can tell it to only operate on specific 'DataVariables' as well.
I think you won't need to use for loop. If A is the name of the table, then you can just use:
A= readtable('dataset.csv');
A{:,:}(A{:,:}==-9) = NaN
9 件のコメント
Megan
2020 年 2 月 12 日
Megan
2020 年 2 月 12 日
Try this:
A= readtable('dataset.csv');
A2 = table2array(A);
A(A==-9) = NaN;
Hope this fix the problem. I checked it using random table in my Matlab.
Megan
2020 年 2 月 12 日
BN
2020 年 2 月 12 日
Undefined operator '==' for input arguments of type 'table'.
did you use this line?
A2 = table2array(A);
After that we have not any table.
Megan
2020 年 2 月 12 日
Megan
2020 年 2 月 12 日
BN
2020 年 2 月 12 日
Oh yes I'm sorry I had a typo, use this:
A= readtable('dataset.csv');
A2 = table2array(A);
A2(A2==-9) = NaN;
Megan
2020 年 2 月 12 日
カテゴリ
ヘルプ センター および File Exchange で Tables についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!