matlab - 在 MATLAB 中从 CSV 文件中读取日期和时间

标签 matlab datetime file-io csv

datetime, M01, M02, M03, M04, M05, M06
8/15/2009 0:00, 5.8, 7.8, 7.8, 7.3, 0, 7.9
8/15/2009 0:10, 7.1, 8.1, 8.1, 7.7, 0, 8.1
8/15/2009 0:20, 6.8, 7.4, 7.6, 7.1, 0, 7.3
8/15/2009 0:30, 5.6, 6.8, 7.1, 6.6, 0, 6.8
8/15/2009 0:40, 3.9, 6.2, 6.4, 6.2, 0, 6.4
8/15/2009 0:50, 4.6, 5.5, 6.1, 5.8, 0, 5.6
8/15/2009 1:40, 7, 7, 7.2, 6.9, 0, 6.3

你能帮我正确阅读这个 CSV 文件,这样我就可以使用 datenum 将第一列转换成字符串吗? ? csvread当然不行。用textscan我不知道怎么调用它,所以我没有得到错误。 日期和时间在同一列中。

抱歉,这听起来可能是个愚蠢的问题!!!

我现在知道如何阅读上面的文件了。但是我如何以完全相同的格式将它写回 file.txt? 我的意思是我修改了一些列,现在需要一个类似的文件,第 1 列和第 1 行具有相同的格式。 感谢您的帮助

最佳答案

根据您上面的评论,如果数据如下所示:

datetime, M01, M02, M03, M04, M05, M06
8/15/2009 0:00, 5.8, 7.8, 7.8, 7.3, 0, 7.9
8/15/2009 0:10, 7.1, 8.1, 8.1, 7.7, 0, 8.1
8/15/2009 0:20, 6.8, 7.4, 7.6, 7.1, 0, 7.3
8/15/2009 0:30, 5.6, 6.8, 7.1, 6.6, 0, 6.8
8/15/2009 0:40, 3.9, 6.2, 6.4, 6.2, 0, 6.4
8/15/2009 0:50, 4.6, 5.5, 6.1, 5.8, 0, 5.6
8/15/2009 1:40, 7, 7 7.2, 6.9, 0, 6.3

然后使用以下内容将其作为矩阵读取:

fid = fopen('file.csv', 'rt');
a = textscan(fid, '%s %f %f %f %f %f %f', ...
      'Delimiter',',', 'CollectOutput',1, 'HeaderLines',1);
fclose(fid);

format short g
M = [datenum(a{1}) a{2}]

...以及我得到的输出:

M =
    7.34e+005        5.8        7.8        7.8        7.3          0        7.9
    7.34e+005        7.1        8.1        8.1        7.7          0        8.1
    7.34e+005        6.8        7.4        7.6        7.1          0        7.3
    7.34e+005        5.6        6.8        7.1        6.6          0        6.8
    7.34e+005        3.9        6.2        6.4        6.2          0        6.4
    7.34e+005        4.6        5.5        6.1        5.8          0        5.6
    7.34e+005          7          7        7.2        6.9          0        6.3

如果设置显示format对于长输出,您将看到完整的数字(注意它们仍然完整存储),或使用 fprintf :

fprintf('%.9f\n', M(:,1))
734000.000000000
734000.006944445
734000.013888889
734000.020833333
734000.027777778
734000.034722222
734000.069444445

关于matlab - 在 MATLAB 中从 CSV 文件中读取日期和时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1641519/

相关文章:

java - 如何使用 jackson 解析具有可变数量的第二个分数的 RFC3339 时间戳

java - 序列化和反序列化 Joda DateTime 对象

c - 从文件中读取数字并将其分配给 C 中的数组时遇到问题

java - 如何将文本文件中的ArrayList填充到JCombobox

c++ - 无法使用 InFile 将文件正确读入结构成员

正弦波一个周期的 Matlab fft 返回 -pi/2 的相位。为什么?

matlab - 时间转换为纪元秒

python - 使用不同的日期时间格式、datetime 和 datetime64 进行计算

c++ - 在类似于 Matlab 的 CAXIS 的 OpenCV 4 (c++) 中设置颜色限制轴

Matlab-给定矩阵 X 和 xi 样本、y 二进制列向量和向量 w 将所有这些绘制成 3d 图形