问题描述:
想读取一个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中。