问题描述:

想读取一个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中。