readcellで要​素の型を指定してcs​vをインポートする方​法を教えてください。

21 次查看(过去 30 天)
K_S_
K_S_ 2023-3-3
回答: covao 2023-3-16
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
covao 2023-3-13
全てのデータをchar文字列として正しく読み込むには、readcell関数ではなく、以下のようにreadtable関数を用いるのが良いようです。
input_data = table2cell(readtable(filename,opts));
K_S_
K_S_ 2023-3-13
無事できました。
ありがとうございました。

请先登录,再进行评论。

采纳的回答

covao
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_wrong = 3×3 cell array
{[1]} {'11a111111'} {[ Inf]} {[2]} {'11b111111'} {[ Inf]} {[3]} {'11c111111'} {'11f111111'}
input_data = table2cell(readtable(filename,opts)) %Correct types
input_data = 3×3 cell array
{'1'} {'11a111111'} {'11d111111'} {'2'} {'11b111111'} {'11e111111'} {'3'} {'11c111111'} {'11f111111'}

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 table 的更多信息

标签

产品


版本

R2022b

Community Treasure Hunt

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

Start Hunting!