26 + 49582.5 1.51 09:31:11 C 28 + 49577.0 1.39 09:31:19 C 30 + 49589.3 0.61 09:31:27 C 32 + 49578.3 1.06 09:31:29 C 34 + 49512.5 1.77 09:31:38 C
解答:直接用 [a,b,c,d,e,f]=textread(yourfilename,'%d %c %f %f %s %c'); 便可
四. 注意事项:
1. 请在 matlab 中保持当前路径在该数据文件对应的目录下进行存取,否则,存取时请给出该数据文件的具体路径。
2. 存取时,请给出该数据文件的全称(包括后缀名,读取mat文件时可省略)
3. load data.txt和A=load(‘data.txt’)的区别请参阅精华贴:[原创]写给学习 matlab 的新手们
4. 请根据读写需要来打开文件,即根据你的需要来指定 fopen 的 permission 属性为读或写。如果只用 a 进行写入,就不能用 fread 读取。此时应该写完关闭文件,然后用 r 打开读取,或者直接用 a+ 进行同时读写操作。否则,会产生莫名其妙的问题!以下代码是一个错误的例子: CODE:
filename='e.dat'; fid=fopen(filename,'a'); if fid<0
error('fopen error'); end
s=[1 2 3 4;5 6 7 8]; fwrite(fid,s,'float32')
[dd ll]=fread(fid,inf,'float32');%把t中的数据全部读出,即s矩阵。
fclose(fid);
此时得到的dd, ll 是错误且无意义的!
五. 其他相关问题:
1. 连续读取多个文件的数据,并存放在一个矩阵中:
(1) 首先是如何读取文件名: 方法一:
filename=dir(‘*.jpg’);
那么第i个文件的文件名就可以表示为 filename(i).name
文件数量为:length(filename)
方法二:
先在Windows的 MSDOS(命令行)中使用以下命令生成一个list.txt文件: dir path\\folder /on /b /s > path\\list.txt
举例:dir d:\\test /on /b /s > d:\\list.txt
然后在 matlab 中使用:
filename = textread(sFileFullName,'%s');
把所有文件名读取到list细胞矩阵中,最后对filename{i}便可得到各文件名。
(2) 然后是读取文件名的数据并存储: 假设每个文件对应的数据是m*n的,则: CODE:
k = length(filename);
Data = zeros(m,n,k);
for ii = 1:k
Data(:,:,ii) = yourreadstyle(filename{ii}); %yourreadstyle是对应的文件读取方式的函数 end
2. 连续读取多个文件的数据,并存放在多个矩阵(以文件名命名)中:
假设每个文件对应的数据是m*n的,则以上述第二种文件名读取方法为例: CODE:
k = length(filename); for ii = 1:k
D = yourreadstyle(filename{ii});
eval([‘Data_’, num2str(ii), ‘ = D;’]); end
3. 文件名命名问题:
文 解答: CODE:
a=cell(879,1); for k=1:879
a{k} = sprintf('%.5d',k); end
件
名
为
abc00001,abc00002,...
abc00009,abc00010,...
abc00099,abc00100,...abc00879. 准备把这些文件名给放到一个数组里面去。
4. 上述各种文件格式、类型自动识别问题:可以利用正则表达式来处理,使之通用性
较强。例如使用以下代码可以自动处理上面提到了例1到例5各种情形,不过由于存在自动判断,对某些例子(如例1)效率自然要低一点,而对于另外的例子(如例3、例5)效率估计要高一点(少用了一个循环)。 CODE:
function [data]=distilldata_eight(infile) %功能说明:
%将保存数据的原始文件中的数值数据读入到一个data变量中(自动判断数据行) %使用说明:
% infile——原始数据文件名; % data=数据变量
tmpfile='tmp2.mat';
fidin=fopen(infile,'r'); % 打开原始数据文件(.list)
fidtmp=fopen(tmpfile,'w'); % 创建保存数据文件(不含说明文字)
while ~feof(fidin) % 判断是否为文件末尾
tline=fgetl(fidin); % 从文件读入一行文本(不含回车键) if ~isempty(tline) % 判断是否空行
str = '[^0-9 | \\. | \\- | \\s | e | E]'; %正则表达式为:该行中是否包含除 - . E e 数字 和 空白字符 外的其他字符
start = regexp(tline,str, 'once'); if isempty(start)
fprintf(fidtmp,'%s\\n',tline); end end end
fclose(fidin);
fclose(fidtmp);
data=textread(tmpfile);
delete(tmpfile)
5. 大量数据的读取问题:
可以考虑使用循环分批读取(特别是在各数据是独立的时候),或者使用稀疏矩阵来实现(对此可以参阅本版精华贴: [原创]提高matlab运行速度和节省空间的一点心得(之三))。另外,也可参考《深入浅出MATLAB 7_X混合编程》一书第一章
6. 读取整个txt文件的内容(获得文件中的所有字符):
CODE:
f = fopen('yourfilename.txt','rt'); % t 属性根据需要可省略 x = fread(f,'*char'); fclose(f);
7. 把维数不同的矩阵及其变量名保存到一个 txt 文件中,例如 a1 = 123; a2 = [1 2 3;4 5 6] ,希望得到的 txt 文件如下:
QUOTE:
a1: 123 a2: 1 2 3 4 5 6
如果写入的时候简单一点,则可以采用以下方式,不过读取的时候比较麻烦:
CODE:
a1=123;
a2=[1 2 3;4 5 6];
fid = fopen('myfile.txt', 'wt'); for i=1:2 fprintf(fid, '%s: \\n %s\\n', ['a',int2str(i)], mat2str(eval(['a',int2str(i)]))); end
fclose(fid);
相反,如果写入的时候复杂一点,则读取的时候会简单一点:
CODE:
a1=123;
a2=[1 2 3;4 5 6];
fid = fopen('myfile.txt', 'wt'); for i=1:2
fprintf(fid, '%s: \\n', ['a',int2str(i)]);
b = eval(['a',int2str(i)]);
fprintf(fid, [repmat('%d ', 1, size(b,2)), '\\n'], b'); end
fclose(fid);