% 打开文件(注意修改文件名)
fid = fopen('480684994.txt','rt');
if fid == 0, return, end
% 读文件直到结束
while ~feof(fid)
% 每次读入一行
s = fgetl(fid);
% 以空格作为数据项的分隔符
% 注意:
% 数据格式必须满足以下要求,否则需要改写代码
% 1、数据的分隔符必须是空格;
% 2、数据项例如“1:0.007477”里面不可以有空格
idx = [0 find(s==' ') length(s)+1];
% 第一项数据
A = [];
A(1) = str2num( s(1:idx(2)-1) );
% 舍去第二列,所以从第三列开始处理
for i = 3 : length(idx) - 1
% 每项有效数据必须包含一个“:”
str = s( idx(i)+1 : idx(i+1) - 1 );
iidx = find( str == ':' );
if length(iidx) ~= 1, continue, end
A(end+1) = str2num( str(iidx+1:end) );
end
% 本行读入的结果保存在变量A中,后续如何处理请自行完成
A
end
% 关闭文件
fclose(fid);
根据txt文档不同种类介绍不同的读取数据方法;
一、纯数据文件(没有字母和中文,纯数字);
二、中英文和数据如test1.txt;
三、中文 数据 英文 混乱如test.txt;
方法一:
file/import data....../next/finish
>> whos
Name Size Bytes Class
data 5x4 160 double array
textdata 4x1 300 cell array
Grand total is 54 elements using 460 bytes
>> data
data =
1 11 111 1111
2 22 222 2222
3 33 333 3333
4 44 444 4444
5 55 555 5555
>> textdata
textdata =
'你好'
'欢迎来到'
'论坛'
'edu.cn'
方法二:
[a1,a2,a3,a4]=textread('test1.txt','%s%s%s%s','headerlines',4)
说明:%s可以是其他形式,跟读入的数据类型有关,比如这里也可以用%n,%f等。
这里%s的个数和[a1,a2,a3,a4]对应。
>> [a1,a2,a3,a4]=textread('test1.txt','%s%s%s%s','headerlines',4)
a1 =
'1'
'2'
'3'
'4'
'5'
a2 =
'11'
'22'
'33'
'44'
'55'
a3 =
'111'
'222'
'333'
'444'
'555'
a4 =
'1111'
'2222'
'3333'
'4444'
'5555'
因以字符串的形式读入,所以有''。
三、中文 数据 英文 混乱如test.txt
你好
1 11 111 1111
欢迎来到
2 22 222 2222
论坛
3 33 333 3333
edu.cn
4 44 444 4444
5 55 555 5555
说明:这种内容格式的文件用上面的方法是不行的。
以下是由chinamaker编写的一种方法:
fidin=fopen('test.txt'); % 打开test2.txt文件
fidout=fopen('mkmatlab.txt','w'); % 创建MKMATLAB.txt文件
while ~feof(fidin) % 判断是否为文件末尾
tline=fgetl(fidin); % 从文件读行
if double(tline(1))>=48&&double(tline(1))<=57 % 判断首字符是否是数值
fprintf(fidout,'%s\n\n',tline); % 如果是数字行,把此行数据写入文件MKMATLAB.txt
continue % 如果是非数字继续下一次循环
end
end
fclose(fidout);
MK=importdata('MKMATLAB.txt'); % 将生成的MKMATLAB.txt文件导入工作空间,变量名为MK,实际上它不显示出来
>> MK
你们老师出的题吗?这么变态,,直接复制粘贴不就完了,干嘛要多此一举.... 非要那么搞的话.就把数据先读进来,然后根据空格来分割数据项,再看看一行有多少列... 完后去掉不要列
到底怎么复杂?给个例子看看
先将所有数据读入到matlab中存储,然后在matlab中对这些数据在进行处理,你看行不行?