matlab中怎么把矩阵数据转换为txt文件

具体的命令是:用save *.txt -ascii x

x为变量
*.txt为文件名,该文件存储于当前工作目录下,再打开就可以 打开后,数据有可能是以指数形式保存的.
看下面这个例子:
a =[17 24 1 8 15;23 5 7 14 16 ;4 6 13 20 22 ;10 12 19 21 3 ;11 18 25 2 9 ];
save afile.txt -ascii a
afile.txt打开之后,是这样的:
1.7000000e+001 2.4000000e+001 1.0000000e+000 8.0000000e+000 1.5000000e+001
2.3000000e+001 5.0000000e+000 7.0000000e+000 1.4000000e+001 1.6000000e+001
4.0000000e+000 6.0000000e+000 1.3000000e+001 2.0000000e+001 2.2000000e+001
1.0000000e+001 1.2000000e+001 1.9000000e+001 2.1000000e+001 3.0000000e+000
1.1000000e+001 1.8000000e+001 2.5000000e+001 2.0000000e+000 9.0000000e+000

网上有很多这一类似的问题,但是都不是很理想,下面介绍一种方法,可以解决以上问题:用fprintf命令:以上面的例子为例:

第一种情况:

>> a=[17 24 1 8 15;23 5 7 14 16 ;4 6 13 20 22 ;10 12 19 21 3 ;11 18 25 2 9 ];
>> fid = fopen('b.txt','w');
fprintf(fid,'%gn',a);       # n 换行
fclose(fid);

然后用写字板打开b.txt,内容如下:为列向量

17
23
4
10
11
24
5
6
12
18
1
7
13
19
25
8
14
20
21
2
15
16
22
3
9

第二种情况:

对上面的命令做一下改动:# n 换行改为t,table键

>> fid = fopen('b.txt','w');
fprintf(fid,'%gt',a);
fclose(fid);

然后用写字板打开b.txt,内容如下:为行向量:

17  23  10  11  24  12  18  13  19  25  14  20  21  15  16  22 
第三种情况:
综合上面的两个结果,我们编写以下命令:
fid=fopen('b.txt','w');%写入文件路径
[m,n]=size(a);
 for i=1:1:m
    for j=1:1:n
       if j==n
         fprintf(fid,'%gn',a(i,j));
      else
        fprintf(fid,'%gt',a(i,j));
       end
    end
end
fclose(fid);
然后用写字板打开b.txt,内容如下:矩阵
17 24 1 8 15
23 5 7 14 16
4 6 13 20 22
10 12 19 21 3
11 18 25 2 9
说明:以上操作都是在当前的工作目录下完成!下面给出最一般的模型,大家可以试着自己操作,如果需要dat格式,直接把txt换为dat就可以,感谢我的同学姜永帅.
fid=fopen('C:Documents and Settingscleantotal.ped',' wt');%写入文件路径
matrix=input_mattrix                                                %input_matrix为待输出矩阵
       [m,n]=size(matrix);
       for i=1:1:m
            for j=1:1:n
                  if j==n
                     fprintf(fid,'%g\n',matrix(i,j));
               else
                  fprintf(fid,'%g\t',matrix(i,j));
               end
         end
     end
     fclose(fid);
相关文章
相关标签/搜索