CSVファイルの時系列演算
    4 ビュー (過去 30 日間)
  
       古いコメントを表示
    
1.のような、ある物質の温度変化の様子が1秒ごとに時系列的に並んでいるCSVデータが100枚ほどあります。このデータを用いて、2.のようなグラフを作りたいのですが、全ての点を折れ線グラフにすることは可能でしょうか?
写真のような物質の温度変化の様子を、1点1点全て折れ線グラフにしたいです。
10 件のコメント
  Keita Abe
      
 2022 年 10 月 14 日
				時間が入っているセルはB3, 温度を取得したいセルがB9ならたとえば,for ループ 以下を次のように書き換えてみてはいかがでしょうか?
for i = 1:length(MyPath)
    M = readmatrix(MyPath(i),'OutputType','string','NumHeaderLines',0);
    time = datetime(M{3,2});
    temperature = str2double(M{9,2});
    TT{i,1} = time;
    TT{i,2} = temperature;
end
TT = cell2table(TT);
plot(TT{:,1},TT{:,2})
採用された回答
  Keita Abe
      
 2022 年 10 月 17 日
        
      編集済み: Keita Abe
      
 2022 年 10 月 18 日
  
      最も愚直に書くとすれば以下のようにデータ取得に対してfor ループを回せばできますね。
clc;clear;
Pathlists = dir("*.csv");
Mylists = (struct2cell(Pathlists))';
Mylists = string(Mylists(:,1:2));
MyPath = fullfile(Mylists(:,2),Mylists(:,1));
for i = 1:length(MyPath)
    M = readmatrix(MyPath(i),'OutputType','string','NumHeaderLines',0);
    time = datetime(M{3,2});
    TT{i,1} = time;
    column =0;
    for j = 0:479
        for k = 0:359
            column = column+1;
            temperature = str2double(M{9+k,2+j});
            TT{i,1+column} = double(temperature);
        end
    end
end
column = 0;
TT = cell2table(TT);
figure;
plot(TT{:,1},TT{:,2:end})
その他の回答 (0 件)
参考
カテゴリ
				Help Center および File Exchange で スプレッドシート についてさらに検索
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!

