http://blog.csdn.net/ysuncn/article/details/1741828

http://zhan.renren.com/h5/entry/3602888498000464631

http://blog.sina.com.cn/s/blog_9444ed240101dxx3.html

1.文件的打开与关闭

  • fopen 打开文件

  在读写文件之前,必须先用fopen函数打开或创建文件,并指定对该文件进行的操作方式。fopen函数的调用格式为: fid=fopen(文件名,“打开方式”) 
  说明:其中fid用于存储文件句柄值,如果返回的句柄值大于0,则说明文件打开成功。文件名用字符串形式,表示待打开的数据文件。常见的打开方式如下: 
  r:只读方式打开文件(默认的方式),该文件必须已存在。

  r+:读写方式打开文件,打开后先读后写。该文件必须已存在。

  w:打开后写入数据。该文件已存在则更新;不存在则创建。
  w+:读写方式打开文件。先读后写。该文件已存在则更新;不存在则创建。

  a:在打开的文件末端添加数据。文件不存在则创建。
  a+:打开文件后,先读入数据再添加数据。文件不存在则创建。
  另外,在这些字符串后添加一个“t”,如“rt‟或”wt+‟,则将该文件以文本方式打开;如果添加的是“b”,则以二进制格式打开,这也是fopen函数默认的打开方式。

  • fclose 关闭文件

  文件在进行完读、写等操作后,应及时关闭,以免数据丢失。关闭文件用fclose函数,调用格式为: sta=fclose(fid) 
  说明:该函数关闭fid所表示的文件。sta表示关闭文件操作的返回代码,若关闭成功,返回0,否则返回-1。如果要关闭所有已打开的文件用fclose(„all‟)。

2.二进制文件的读写

  • fwrite 写二进制文件 
    fwrite函数按照指定的数据精度将矩阵中的元素写入到文件中。其调用格式为: COUNT=fwrite(fid,A,precision) 
    说明:其中COUNT返回所写的数据元素个数(可缺省),fid为文件句柄,A用来存放写入文件的数据,precision代表数据精度,常用的数据精度有:char、uchar、int、long、float、double等。缺省数据精度为uchar,即无符号字符格式。 
    例6.8 将一个二进制矩阵存入磁盘文件中。

>> a=[1 2 3 4 5 6 7 8 9];

>> fid=fopen('d:\test.bin','wb') %以二进制数据写入方式打开文件

     fid = 3 %其值大于0,表示打开成功

   >> fwrite(fid,a,'double')

    ans =  9 %表示写入了9个数据

  • fread 读二进制文件

  fread函数可以读取二进制文件的数据,并将数据存入矩阵。其调用格式为: [A,COUNT]=fread(fid,size,precision) 
  说明:其中A是用于存放读取数据的矩阵、COUNT是返回所读取的数据元素个数、fid为文件句柄、size为可选项,若不选用则读取整个文件内容;若选用则它的值可以是下列值:N(读取N个元素到一个列向量)、inf(读取整个文件)、[M,N](读数据到M×N的矩阵中,数据按列存放)。 precision用于控制所写数据的精度,其形式与fwrite函数相同。

3.文本文件的读写操作

  • 读文本文件

  fscanf函数可以读取文本文件的内容,并按指定格式存入矩阵。其调用格式为: [A,COUNT]=fscanf(fid,format,size) 
  说明:其中A用来存放读取的数据,COUNT返回所读取的数据元素个数,fid为文件句柄,format用来控制读取的数据格式,由%加上格式符组成,常见的格式符有:d(整型)、f(浮点型)、s(字符串型)、c(字符型)等,在%与格式符之间还可以插入附加格式说明符,如数据宽度说明等。size为可选项,决定矩阵A中数据的排列形式,它可以取下列值:N(读取N个元素到一个列向量)、inf(读取整个文件)、[M,N](读数据到M×N的矩阵中,数据按列存放)。   
  matlab中的fscanf的用法如下:

  A=fscanf(fid,format)

  [A, count]=fscanf(fid,format,size)

  个人感觉用的最多的是这样的形式: 
  data = fscanf(fid,format,size); 
  其中data为读取内容的数组,它的大小由size决定。size是一个[m n]的向量,m为行,n为列(注意,这里读取的顺序是按列优先排列的,不明白的话可以看下面的例子),若n取inf表示读到文件末尾。fid为fopen打开文件的返回值,format是格式化参数(像printf、scanf)。

  matlab读txt文件

  fid=fopen('fx.txt','r'); %得到文件号 
  [f,count]=fscanf(fid,'%f %f',[12,90]); 
  %把文件号1的数据读到f中。其中f是[12 90]的矩阵

  %这里'%f %f'表示读取数据的形式,按原始数据型读出

   fclose(fid); %关闭文件

  举个小例子: 
  路径+文件名:d:\moon.txt

  内容:13,1,3.4

   3,2.1,23

1, 12, 2 

     4,5.4,6

  现在为了读取moon.txt中的数据存在一个数组里,可以用如下方法: 
 
  fid=fopen('d:\moon.txt'); 
  data=fscanf(fid,'%f,%f,%f',[3,inf]) %这里得用单引号

  fclose(fid); 
 
  这时data中的数据如下:(3行4列,matlab元素按照列的顺序排列) 
 
  13    3     1       4 
 
  1     2.1   12     5.4 
 
  3.4     23     2      6  
 
  再看一个运行实例:

  data=fscanf(fid,'%f,%f,%f',[4,inf]);

  fclose(fid);

  13 2.1  2
  1 23 4
    3.4 1 5.4
  3 12 6

  • fprintf 写文本文件

  fprintf函数可以将数据按指定格式写入到文本文件中。其调用格式为: fprintf(fid,format,A) 
  说明:fid为文件句柄,指定要写入数据的文件,format是用来控制所写数据格式的格式符,与fscanf函数相同,A是用来存放数据的矩阵。 
  例6.9 创建一个字符矩阵并存入磁盘,再读出赋值给另一个矩阵。

  >> a='string'; 
  >> fid=fopen('d:\char1.txt','w');

  >> fprintf(fid,'%s',a);

  >> fclose(fid); 
  >> fid1=fopen('d:\char1.txt','rt');

   >> b=fscanf(fid1,'%s')

  b =       string

4.数据文件定位 
  MATLAB提供了与文件定位操作有关的函数fseek和ftell。

  • fseek函数用于定位文件位置指针,其调用格式为:

  status=fseek(fid, offset, origin) 
  其中fid为文件句柄,offset表示位置指针相对移动的字节数,OFFSET values are interpreted as follows:

      > 0    Move toward the end of the file.

      = 0    Do not change position. 
      < 0    Move toward the beginning of the file. 
  origin表示位置指针移动的参照位置,ORIGIN values are interpreted as follows:

       'bof' or -1  Beginning of file

      'cof' or 0   Current position in file

      'eof' or 1   End of file 
  若定位成功,status返回值为0,否则返回值为–1。

  • ftell函数返回文件指针的当前位置,其调用格式为: position=ftell (fid)

  返回值为从文件开始到指针当前位置的字节数。若返回值为–1表示获取文件当前位置失败。 例: 
  FID=fopen('sw.m','r')

  fseek(FID,10,-1)

   ans =      0

  >> ftell(FID)

  ans =     10 
  >> fseek(FID,-10,1)

  ans =      0 

  >> ftell(FID)

  ans =         2180 
  文件指针可以移动到当前文件末尾的后面,但不能移动到开头的前面;当把指针移动到文件末尾后面时,若关闭文件则文件大小会自动增长到文件指针所指的大小,用这种方法可以很容易创建一个很大的文件,当然新增加的文件内容是随机的


5.prod  

  B = prod(A) 
  B = prod(A,dim) 
  B = prod(A,'double') 
  B = prod(A,'native')

  Prod函数是求积,用法和sum函数基本上差不多,但是也有一些区别,相同的部分不在赘述,只将差异简单描述一下:

  按照帮助文件中来看,sum函数有6中重载的方法,prod函数只有4种,如果选择了按某一维计算,则无法控制输出的数据类型,事实上,不是这么一回事,大家可以试一试,prod是可以带3个参数,和sum函数一样,所以我觉得帮助文件里面少些了和sum一样的2种重载的方法。

  >> a = single(magic(3))

  a =   

    8     1     6

   3     5     7

   4     9     2

  >> b = prod(a,2,'native')   % 带3个参数

  b =

  48

   105

   72

  >> class(b)

  ans =

  single

  prod函数无法对整数类型进行计算,只能对浮点型的数据计算。

6. reshape

  看Matlab的help文档讲得不是清楚。
  先给上一段代码:
  >> a=[1 2 3;4 5 6;7 8 9;10 11 12];
  >> b=reshape(a,2,6);
  这段代码的结果是这样的:
  >> a
     1     2     3
     4     5     6
     7     8     9
    10    11    12
  >> b
     1     7     2     8     3     9
     4    10     5    11     6    12
  对于  b=reshape(a,m,n);
  其中的规律是这样的,先把矩阵a按列拆分,然后拼接成一个大小为m*n的向量。然后对这个向量每隔m间隔取一个元素组成一个向量b_i,之后的向量b_i+1也是这样生成,只不过第一个元素往下移一位。这样做完之后得到m个大小为n的行向量,将这些行向量拼接  即可得到矩阵b。
 
7.fliplr

  fliplr  左右翻转矩阵

  语法:B = fliplr(A)

  将矩阵A的列绕垂直轴进行左右翻转 matabc 
  如果A是一个行向量,fliplr(A)将A中元素的顺序进行翻转。 
  如果A是一个列向量,fliplr(A)还等于A。

  举例说明:
  例一:如果A是一个3×2的矩阵

  A =[1 4 
             2 5 
             3 6 ] 

  fliplr(A) 
  ans = [4 1 
           5 2 
           6 3 ]

  例二:如果A是一个行向量

  A = [1 3 5 7 9 ]

  fliplr(A) 
  ans = [9 7 5 3 1 ]
  例三:如果A是一个列向量

  A = [1 
               3 
               5 
               7 
               9]

  fliplr(A) 
  ans = [1 
           3 
           5 
           7 
           9]

 
 

matlab操作(整理)的更多相关文章

  1. Matlab操作矩阵的相关方法

    Matlab操作矩阵的相关方法 下面这篇文章主要是对吴恩达老师机器学习中matlab操作的一个整理和归纳 一.基本操作 1.生成矩阵(ones.zeros) A = [1 2;3 4;5 6]    ...

  2. SQL不同服务器数据库之间的数据操作整理(完整版)

    ---------------------------------------------------------------------------------- -- Author : htl25 ...

  3. 转载-SQL不同服务器数据库之间的数据操作整理(完整版) .

    ---------------------------------------------------------------------------------- -- Author : htl25 ...

  4. javascript中字符串常用操作整理

    javascript中字符串常用操作整理 字符串的操作在js中非常频繁,也非常重要.以往看完书之后都能记得非常清楚,但稍微隔一段时间不用,便会忘得差不多,记性不好是硬伤啊...今天就对字符串的一些常用 ...

  5. SVG.js 元素操作整理(二)-Transform

    一.transform()获取或设置矩阵变换 var draw = SVG('svg1').size(300, 300); //Transforming SVG元素矩阵变换 var rect = dr ...

  6. js的DOM操作整理(整理)

    js的DOM操作整理(整理) 一.总结 一句话总结: dom操作有用原生js的dom操作,也可以用对js封装过的jquery等插件来更加方便的进行dom操作 1.dom是什么? 对于JavaScrip ...

  7. vim程序编辑器---常用操作整理

    vim程序编辑器---常用操作整理 移动光标方法 o 在光标行的下一行,进入编辑模式 $ 移动到光标这行,最末尾的地方 G(大写) 移动到文件最末行 :set  nu 文件显示行数 :set  non ...

  8. .NET 对 XML 进行创建,增加,删除,修改操作整理

    前言: 最近做了一个项目,程序A在一个服务器程序B在另一台服务器,然而主程序A需要访问程序B的图片集文件夹下载到本服务器上,为了防止多次对Web Services进行调用,在主程序A中创建一个XML文 ...

  9. c文件操作整理

    <c陷阱与缺陷> FILE *fp; fp = fopen(file, "r+"); 编程者也许认为,程序一旦执行上述操作完毕,就可以自由地进行读取和写入的操作了.遗憾 ...

随机推荐

  1. SpringBoot入门 (三) 日志配置

    上一篇博文记录了再springboot项目中读取属性文件中配置的属性,本文学习在springboot项目中记录日志. 日志记录在项目中是很常见的一个功能了,对排查问题有很大帮助,也可以做分类分析及统计 ...

  2. [转]使用BCP导出导入数据

    本文转自:http://www.cnblogs.com/zerocc/p/3225723.html bcp 实用工具可以在 Microsoft SQL Server 实例和用户指定格式的数据文件间大容 ...

  3. css3如何实现圆角边框

    圆角边框是css3新增属性,在圆角边框出现之前,前端开发有的采用整块的圆角图片作为背景,有的采用小的圆角图片分别放在元素的四角,非常麻烦,灵活性差,也达到降低了网站的整体性能,而圆角边的出现则降低了开 ...

  4. 如果你的shiro没学明白,那么应该看看这篇文章,将shiro整合进springboot

    最近在做项目的时候需要用到shiro做认证和授权来管理资源 在网上看了很多文章,发现大多数都是把官方文档的简介摘抄一段,然后就开始贴代码,告诉你怎么怎么做,怎么怎么做 相信很多小伙伴即使是跟着那些示例 ...

  5. Jetty源码解析(web.xml的处理机制)

    org.eclipse.jetty.webapp 包下的 StandardDescriptorProcessor类.该类对象会在WebAppContext的doStart方法启用 注册了遍历web.x ...

  6. Java的工厂模式(二)

    除了上文提到的方法之外,还可以使用Java的反射机制,这样就能使用类名称来加载所需要的类.我们只需改变工厂类和驱动类就可以了. FruitFactory.java package com.muggle ...

  7. easyUi datagrid鼠标经过提示单元格内容

    此文章是基于 EasyUI+Knockout实现经典表单的查看.编辑 一. jquery.cellTip.js /** * 扩展两个方法 */ using('datagrid', function() ...

  8. Servlet自动注入Spring容器中的Bean解决方法

    很多情况在进行Web开发的时候需要自己手写Servlet来完成某些功能,而servlet有需要注入Spring容器中的某些bean,这是每次都要手动获取比较麻烦,这里有一个解决方案,只需要写一个ser ...

  9. 移动web模拟客户端实现多方框输入密码效果

    不知道怎么描述标题,先看截图吧,大致的效果就是一个框输入一位密码. 最开始实现的思路是一个小方框就是一个type为password的input,每输入一位自动跳到下一位,删除一位就自动跳到前一位,an ...

  10. shiro标签的使用

    guest标签   用户没有身份验证时显示相应信息,即游客访问信息. user标签    用户已经身份验证/记住我登录后显示相应的信息. authenticated标签     用户已经身份验证通过, ...