• 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,'%g ',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

     

    第二种情况:

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

     

    >> fid = fopen('b.txt','w');
    fprintf(fid,'%g ',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,'%g ',a(i,j));
          else
            fprintf(fid,'%g ',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 ',matrix(i,j));
              else
               fprintf(fid,'%g ',matrix(i,j));
             end
          end
         end
         fclose(fid);
  • 相关阅读:
    Jenkins配置钉钉通知
    Jenkins 学习笔记
    2020年10月26日Britain suggests it may overturn parts of the EU withdrawal agreement
    【火爆抢答中】HarmonyOS有奖问答,更多惊喜等你来拿!
    三七互娱《斗罗大陆:魂师对决》上线,Network Kit助力玩家即刻畅玩
    运动健康南向设备接入服务传输数据解析举例
    华为商品管理系统批量更新商品时提示:请至少输入一组国家码和价格
    云空间服务,助力用户数据存储与协同
    Input组件无点击效果
    华为视频编辑服务(Video Editor Kit),助力开发者高效构建应用视频编辑能力
  • 原文地址:https://www.cnblogs.com/jiangnanrain/p/3555252.html
Copyright © 2020-2023  润新知