poster
2019-12-10, 16:49
我有一个具有以下结构的文本文件:
1999-01-04 1,100.00 1,060.00 1,092.50 0 6,225 1,336,605 37 1999-01-05 1,122.50 1,087.50 1,122.50 0 3,250 712,175 14 ... 该文件包含八个值的重复集合(一个日期后跟七个数字,每个数字在各自的行中)。
我想将其读入MATLAB并将值转换为不同的向量。我尝试使用几种不同的方法来完成此操作,但是没有一种有效-所有方法都输出某种错误。
万一重要,我可以在Mac上进行。
回答:
编辑:这是我以前在我的答案中的代码的简短版本...
如果您想直接读取数据文件,而不必按照dstibbe的建议 (https://stackoverflow.com/questions/1492268/read-data-into-matlab-from-textfile/1492294#1492294)先对其 (https://stackoverflow.com/questions/1492268/read-data-into-matlab-from-textfile/1492294#1492294)进行预处理, 则应 (https://stackoverflow.com/questions/1492268/read-data-into-matlab-from-textfile/1492294#1492294)执行以下操作:
fid = fopen('datafile.txt','rt'); data = textscan(fid,'%s %s %s %s %s %s %s %s','Delimiter','\n'); fclose(fid); data = [datenum(data{1}) cellfun(@str2double,[data{2:end}])]'; 上面的代码将每组8个值放入一个8×N矩阵中,其中N是数据文件中8行集的数量。该日期将转换为序列日期号,以便可以将其与矩阵中的其他双精度值一起包含。以下功能(在以上代码中使用)可能是您感兴趣的: TEXTSCAN (http://www.mathworks.com/access/helpdesk/help/techdoc/ref/textscan.html) , DATENUM (http://www.mathworks.com/access/helpdesk/help/techdoc/ref/datenum.html) , CELLFUN (http://www.mathworks.com/access/helpdesk/help/techdoc/ref/cellfun.html) , STR2DOUBLE (http://www.mathworks.com/access/helpdesk/help/techdoc/ref/str2double.html) 。
更多&回答... (https://stackoverflow.com/questions/1492268)
1999-01-04 1,100.00 1,060.00 1,092.50 0 6,225 1,336,605 37 1999-01-05 1,122.50 1,087.50 1,122.50 0 3,250 712,175 14 ... 该文件包含八个值的重复集合(一个日期后跟七个数字,每个数字在各自的行中)。
我想将其读入MATLAB并将值转换为不同的向量。我尝试使用几种不同的方法来完成此操作,但是没有一种有效-所有方法都输出某种错误。
万一重要,我可以在Mac上进行。
回答:
编辑:这是我以前在我的答案中的代码的简短版本...
如果您想直接读取数据文件,而不必按照dstibbe的建议 (https://stackoverflow.com/questions/1492268/read-data-into-matlab-from-textfile/1492294#1492294)先对其 (https://stackoverflow.com/questions/1492268/read-data-into-matlab-from-textfile/1492294#1492294)进行预处理, 则应 (https://stackoverflow.com/questions/1492268/read-data-into-matlab-from-textfile/1492294#1492294)执行以下操作:
fid = fopen('datafile.txt','rt'); data = textscan(fid,'%s %s %s %s %s %s %s %s','Delimiter','\n'); fclose(fid); data = [datenum(data{1}) cellfun(@str2double,[data{2:end}])]'; 上面的代码将每组8个值放入一个8×N矩阵中,其中N是数据文件中8行集的数量。该日期将转换为序列日期号,以便可以将其与矩阵中的其他双精度值一起包含。以下功能(在以上代码中使用)可能是您感兴趣的: TEXTSCAN (http://www.mathworks.com/access/helpdesk/help/techdoc/ref/textscan.html) , DATENUM (http://www.mathworks.com/access/helpdesk/help/techdoc/ref/datenum.html) , CELLFUN (http://www.mathworks.com/access/helpdesk/help/techdoc/ref/cellfun.html) , STR2DOUBLE (http://www.mathworks.com/access/helpdesk/help/techdoc/ref/str2double.html) 。
更多&回答... (https://stackoverflow.com/questions/1492268)