我正在读取具有以下格式的csv文件:
Header:,Date,Time,"MC2_Y241_TightnessPressValve","MC2_Y243_PressingValve""
Data,2015-09-16,15:41:52;781,"780.000000","0.0034"
Data,2015-09-16,15:41:52;791,"790.000000","0.1255"
Data,2015-09-16,15:41:52;801,"800.000000","1.5123"
Atm我正在使用fgetl(fid)查找标题以及所有日期和时间。然后,我使用有关哪些行和列包含双精度的知识,以便能够使用csvread()快速读取。但是,要使用csvread(),我必须首先删除引号。我目前正在使用matlab中的Powershell脚本来执行此操作,但是这太耗时,因为我需要读取+ 200Mb的文件。
注意:不能使用带有'%q'的textscan的原因有两个:1)我希望将所有双打立即读取为双打(转换太耗时)。2)文件包含各种数量的行和列。
这是针对独立应用程序的。
我非常感谢所有帮助,我花了无数小时来提高效率。
我虽然应该发布答案,以防其他人遇到同样的问题。感谢Lee帮了我的忙!
% Remove quotes
fid = fopen('temp.csv','w');
s = fileread('myFile.csv');
s = strrep(s,'"','');
fprintf(fid,s);
fclose(fid);
% Open new, quote free, file
fid = fopen('temp.csv','r');
% Get Headers
Headers{1} = fgetl(fid);
Headers = textscan(Headers{1},'%s','Delimiter',',');
Headers = Headers{1};
Headers = Headers(3:end);
% Get date and time
lineIndex = 1;
nextLine = fgetl(fid);
time{lineIndex} = nextLine(6:28);
lineIndex = lineIndex + 1;
nextLine = fgetl(fid);
while ~isequal(nextLine,-1) && ~isempty(nextLine)
time{lineIndex} = nextLine(6:28);
lineIndex = lineIndex + 1;
nextLine = fgetl(fid);
end
% Get doubles
Data = csvread('temp.csv', 1,3);
fclose(fid);
% Convert time with datenum
Time = datenum(time,'yyyy-mm-dd,HH:MM:SS;FFF');
% Put all data in one matrix
Data = [Time, Data];
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句