readcellで要素の型を指定してcsvをインポートする方法を教えてください。
13 ビュー (過去 30 日間)
古いコメントを表示
readcellでcsvファイルを読み込む際に、cell内に元の数値(9桁の16進数)が格納されず、"Inf"が格納されてしまい困っています。
現在書いたコードではd, eの後が数字のみのため、指数表記と認識されているようです。
正しく動作させる方法を教えてください。
filename = 'test.csv';
numVars = 3;
varTypes = {'char','char','char'};
delimiter = ',';
dataStartLine = 2;
opts = delimitedTextImportOptions('NumVariables',numVars, ...
'VariableTypes',varTypes,...
'Delimiter',delimiter,...
'DataLines', dataStartLine);
input_data = readcell(filename,opts);
2 件のコメント
covao
2023 年 3 月 13 日
全てのデータをchar文字列として正しく読み込むには、readcell関数ではなく、以下のようにreadtable関数を用いるのが良いようです。
input_data = table2cell(readtable(filename,opts));
採用された回答
covao
2023 年 3 月 16 日
解決とのご連絡ありがとうございます。
再現するコードをこちらに記述しておきます。
filename='https://jp.mathworks.com/matlabcentral/answers/uploaded_files/1312970/test.csv';
numVars = 3;
varTypes = {'char','char','char'};
delimiter = ',';
dataStartLine = 2;
opts = delimitedTextImportOptions('NumVariables',numVars, ...
'VariableTypes',varTypes,...
'Delimiter',delimiter,...
'DataLines', dataStartLine);
input_data_wrong = readcell(filename,opts) %Wrong types!
input_data = table2cell(readtable(filename,opts)) %Correct types
0 件のコメント
その他の回答 (0 件)
参考
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!