numericでない列をnumericに変換してcsvreadしたい
조회 수: 4 (최근 30일)
이전 댓글 표시
채택된 답변
mizuki
2017년 12월 12일
편집: mizuki
2017년 12월 12일
importtool を使用して読み込みを行うと一番楽ですが、読み込み関数は csvread である必要はありますか?
ファイル自体からダブルクオーテーションを抜いてから読み込むのは二度手間になるため、フォーマットを指定する方法を取る方法ではいかがでしょうか。
importtool を使用して作成した読み込み関数 importfile を添付します。実際の読み込み関数は、ダブルクオーテーションとカンマを抜くような形式を指定して textscan を使用しています。
使用方法は以下のようになります。
filename = 'csvread_answers.csv';
tbl = importfile(filename);
フォーマットは以下のように指定されています。
formatSpec = '%q%q%q%q%q%q%q%[^\n\r]';
また、importfile.m の内容を確認するには
edit importfile
と実行します。
댓글 수: 0
추가 답변 (2개)
Y.Suzuki
2017년 12월 14일
댓글 수: 1
mizuki
2017년 12월 14일
>> class(tbl)
importfile.m の86行目に、
csvreadanswers = table;
という行があります。これは、出力引数 csvreadanswers が table 型ということを定義しています。
エラーが起こったときには、問題をまず細かく分けて一つずつ解決していく必要があります。今回の場合、
>> tbl(2,4)*3
が実行できないということですが、このような場合、
>> tbl(2,4)
が実行できるかを見ていきましょう。
>> tbl(2,4)
ans =
table
VarName4
________
0
となっていますよね。これも数値型ではなく table 型になってしまっているため、直接掛け算をすることができません。(例えばVarName4 * 3 はできない)
これを解決する方法は、table 型から数値型に直す方法と、table 型から数値だけを抜き出す方法の2つがあります。
1. table 型から数値型に直す方法
table2array 関数を使用します。ただし、table 型が持っているヘッダ情報などは消えますのでご注意ください。
>> num = table2array(tbl)
2. table 型から数値だけを抜き出す方法
中括弧 {} を使用します。
>> tbl{2,4}
참고 항목
카테고리
Help Center 및 File Exchange에서 標準ファイル形式에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!