Go through the table with a loop and change values

I have 30 columns and there are values in these columns.

2 commentaires

BN
BN le 12 Fév 2020
Modifié(e) : BN le 12 Fév 2020
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 le 12 Fév 2020
yes

Connectez-vous pour commenter.

Réponses (3)

Subhadeep Koley
Subhadeep Koley le 12 Fév 2020
Modifié(e) : Subhadeep Koley le 12 Fév 2020
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 commentaires

Megan
Megan le 12 Fév 2020
columnData(:, i) = table2array(data(:, i)); % columnData variable contains your column values
I dont get this part. Where do I have to write my if statement
pseudocode:
if data == -9
data = NaN
end
@Oz Sorry, I got your point now. I have changed the answer accordingly.
Megan
Megan le 12 Fév 2020
I get this error msg
Undefined operator '==' for input arguments of type 'cell'.
Error in analysis (line 16)
if table2array(data(i, j)) == -9
@Oz Can you post the dataset.csv file?
Megan
Megan le 12 Fév 2020
I've uploaded it
Megan
Megan le 12 Fév 2020
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
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

Connectez-vous pour commenter.

Steven Lord
Steven Lord le 12 Fév 2020

1 vote

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 le 12 Fév 2020
Modifié(e) : BN le 12 Fév 2020
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 commentaires

Megan
Megan le 12 Fév 2020
Error using analysis (line 22)
Unable to concatenate the table variables 'CASE' and 'QUESTNNR', because their types are
double and cell.
Megan
Megan le 12 Fév 2020
Error using ==
Too many input arguments.
Error in analysis (line 25)
A{:,:}(A{:,:}== -9) = NaN
Did you try it?
BN
BN le 12 Fév 2020
Modifié(e) : BN le 12 Fév 2020
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
Megan le 12 Fév 2020
Undefined operator '==' for input arguments of type 'table'.
Error in analysis (line 25)
A(A==-9) = NaN;
Thank you, but It did not work :(
Undefined operator '==' for input arguments of type 'table'.
did you use this line?
A2 = table2array(A);
After that we have not any table.
Megan
Megan le 12 Fév 2020
yes I did
Megan
Megan le 12 Fév 2020
but we never use A2 right?
Oh yes I'm sorry I had a typo, use this:
A= readtable('dataset.csv');
A2 = table2array(A);
A2(A2==-9) = NaN;
Megan
Megan le 12 Fév 2020
No, it did not work :(
Undefined operator '==' for input arguments of type 'cell'.
Error in analysis (line 25)
A2(A2==-9) = NaN;

Connectez-vous pour commenter.

Catégories

Question posée :

le 12 Fév 2020

Modifié(e) :

le 19 Fév 2020

Community Treasure Hunt

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

Start Hunting!

Translated by