CSVファイルから特​定の列のデータのみ取​得する方法

71 vues (au cours des 30 derniers jours)
yuuji yamada
yuuji yamada le 9 Nov 2018
Commenté : yuuji yamada le 12 Nov 2018
Matlab2018aを使用しています。 メモリ節約のため、textscanで600000行のCSVデータを20000行ずつ読み込み、 3列目のデータの20000個の平均を算出したいと思っています。 下記のようなプログラムを書いたのですがループが入れ子になっており 速度が遅いです。 data{1}は20000x1 のcell型配列になっています。 data{1}から3列目のデータを20000個素早く取得する方法はないでしょうか。
for i=1:30
data = textscan(fileID, '%s', 20000);
% 20000回ループ
for j=1:length(data{1})
% CSVデータの3列目のみを2000個取得
end
% 取得した2000個のデータを平均する処理
end
close(fileID);

Réponse acceptée

mizu
mizu le 9 Nov 2018
datastore で、読み込む前に列を絞ってはいかがでしょうか.
ヘルプの例にあるように、SelectedVariablename で読み込む列を指定することができます。
  1 commentaire
yuuji yamada
yuuji yamada le 12 Nov 2018
教えて頂いたdatastoreを使用して実現することができました。 ありがとうございました。

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur 言語の基礎 dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!