CSVファイルの時系列演算
조회 수: 11 (최근 30일)
이전 댓글 표시
data:image/s3,"s3://crabby-images/620ff/620ff0157b9d1ef5fd43abf8ca27b2ff0f4aa3fc" alt=""
data:image/s3,"s3://crabby-images/155f6/155f643733d04c34cb2d6f3b33e3e680a7acf6d4" alt=""
写真のような物質の温度変化の様子を、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개)
참고 항목
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!