大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺
问题描述:
想读取一个txt文本中的很多数据。数据之前有几行是中文,然后才是数据,如何用MATLAB读取txt文件中标识符所对应的列啊,多谢指教了!文件大概是这样的:
你好欢迎来到…………sum1 sum2 sum3 sum41 11 111 11112 22 222 22223 33 333 33334 44 444 44445 55 555 5555目标是逐行扫描后找到特定标识符‘sum2’,并保存与sum2相对应的列。即 sum21122334455另: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中。
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/196912.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...