Go through the table with a loop and change values

조회 수: 22 (최근 30일)
Megan
Megan 2020년 2월 12일
편집: Megan 2020년 2월 19일
I have 30 columns and there are values in these columns.
  댓글 수: 2
BN
BN 2020년 2월 12일
편집: BN 2020년 2월 12일
Hello, Do you want to replace -9 to NaN across your table? I mean You want to change every -9 in your table to NaN?
Megan
Megan 2020년 2월 12일
yes

댓글을 달려면 로그인하십시오.

답변 (3개)

Subhadeep Koley
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
Megan 2020년 2월 12일
the empty rows are coded automatically as NaN in Matlab.
In my Questionnare -9 also means Error so, I want to change -9 into NaN
Subhadeep Koley
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
Steven Lord 2020년 2월 12일
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.

BN
BN 2020년 2월 12일
편집: BN 2020년 2월 12일
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
BN
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
Megan 2020년 2월 12일
No, it did not work :(
Undefined operator '==' for input arguments of type 'cell'.
Error in analysis (line 25)
A2(A2==-9) = NaN;

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Tables에 대해 자세히 알아보기

태그

Community Treasure Hunt

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

Start Hunting!

Translated by