Strings are converted to cells during readtable
88 visualizzazioni (ultimi 30 giorni)
Mostra commenti meno recenti
I am incrementally saving data to a csv file which includes strings:
data = table("string1", "string2");
writetable(data, "data.csv");
Later on:
data_from_file = readtable('data.csv')
data_from_file =
1×2 table
Var1 Var2
___________ ___________
{'string1'} {'string2'}
Note that the data are now char arrays in cells.
This is causing lots of problems, for example when I try to join the old data with the new:
new_data = table("string1", "string2");
data = outerjoin(data_from_file, new_data, 'MergeKeys', true)
Error using tabular/outerjoin (line 152)
Left and right key variables 'Var1' and 'Var1' are not comparable because one is
a non-cell.
Is there a way to avoid this problem or convert the chars back to strings after readtable?
2 Commenti
Risposta accettata
Più risposte (2)
Adam Danz
il 4 Gen 2024
When using the readtable(filename,opts,Name,Value) syntax, only a limited number of name-values pairs are available as input arguments and TextType is not one of them. If you are using the import options object and would like to enforce strings for text type, specify this name-value pair as an argument in detectImportOptions()
opts = detectImportOptions(filename,'TextType','string');
T = readtable(filename,opts)
0 Commenti
KSSV
il 10 Giu 2022
You can convert cell into a string and then use join.
data = table("string1", "string2");
writetable(data, "data.csv");
data_from_file = readtable('data.csv') ;
for i = 1:width(data_from_file)
data_from_file.(i) = string(data_from_file.(i)) ;
end
new_data = table("string3", "string4");
data = outerjoin(data_from_file, new_data, 'MergeKeys', true)
0 Commenti
Vedere anche
Categorie
Scopri di più su Cell Arrays in Help Center e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!