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行。 谢谢你的帮助
答案 0 :(得分:15)
根据您上面的评论,如果数据如下:
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
答案 1 :(得分:2)
TEXTSCAN本身不会转换日期,但您可以只在需要它的列上调用DATENUM。
f = fopen('datafile.txt');
data = textscan(f, '%s %f %f %f %f %f %f', 'Delimiter', ',', 'HeaderLines', 1);
fclose(f);
data{1} = datenum(data{1});
将返回双精度数组data
,其中第一列是与每个日期对应的MATLAB datenum,而另一列是文件中的相应列。