基本实现想法是:
因为每一行的长度是固定的,大小也是固定的(下面的例子是42,因此下面代码的参数会有 (fisize/42)),所以整个文本的大小除以每一行的大小就可以得到这个文本的行数;
再把这个行数用到textscan函数中,就可以直接读取最后一行的内容。
fid = fopen('E:\matlab2015a\projects\test\char1.dat','rt');
fseek(fid,0,'eof');fsize = ftell(fid); %获得文件的大小
frewind(fid); %让文件位置指针返回首地址,textscan会用到
C = textscan(fid,'%d-%d-%d %d:%d:%d %s %s %s %d',1,'HeaderLines',(fsize/42)-1); %要注意参数的填写
fclose(fid);
在命令行中输出的结果如下:
>> test
K>> C
C =
[2017] [8] [16] [9] [36] [7] {1x1 cell} {1x1 cell} {1x1 cell} [128]
结果与我要的完全一致,而且没有用循环之类的,效率上会很高。