问题描述:
想读取一个txt文本中的很多数据。数据之前有几行是中文,然后才是数据,如何用MATLAB读取txt文件中标识符所对应的列啊,多谢指教了!文件大概是这样的:
你好
欢迎来到
............
sum1 sum2 sum3 sum4
1 11 111 1111
2 22 222 2222
3 33 333 3333
4 44 444 4444
5 55 555 5555
目标是逐行扫描后找到特定标识符‘sum2’,并保存与sum2相对应的列。
即 sum2
11
22
33
44
55
另:sum2下面只有一部分数据,还有一部分和这一部分类似,但列数不同,您能教我一下想要提取sum2下的列用什么函数吗?
解决办法:
读取行以后得到sum2所在的列,然后接着往下读取数据,把数据用空格切割,保留sum2所在的列的数据
fid=fopen('save.txt','r');
line = fgetl(fid);
while~feof(fid)&&isempty(strfind(line,'sum2'))
line=fgetl(fid);
end
str = strsplit(line,' ');
%查找sum2所在的列程序段,自己添加
index = 2;
%这里我简单的令其为2了
yourmat = [];
while~feof(fid)
line=fgetl(fid);
str = strsplit(line,' ');
if isempty(str{1})
yourmat = [yourmat; str2double(str{index+1})];
else
yourmat = [yourmat; str2double(str{index})];
end
end
fclose(fid);
源数据保存在save.txt中。