文本文件存取技巧

上传人:xzh****18 文档编号:34770258 上传时间:2018-03-01 格式:DOC 页数:20 大小:80KB
返回 下载 相关 举报
文本文件存取技巧_第1页
第1页 / 共20页
文本文件存取技巧_第2页
第2页 / 共20页
文本文件存取技巧_第3页
第3页 / 共20页
文本文件存取技巧_第4页
第4页 / 共20页
文本文件存取技巧_第5页
第5页 / 共20页
点击查看更多>>
资源描述

《文本文件存取技巧》由会员分享,可在线阅读,更多相关《文本文件存取技巧(20页珍藏版)》请在金锄头文库上搜索。

1、一. 基本知识: -转- - 1. 二进制文件与文本文件的区别: 将文件看作是由一个一个字节(byte) 组成的, 那么文本文件中的每个字节的最高位都是0, 也就是说文本文件使用了一个字节中的七位来表示所有的信息,而二进制文件则是将字节中的 所有位都用上了。这就是两者的区别;接着,第二个问题就是文件按照文本方式或者二进制方 式打开,两者会有什么不同呢?其实不管是二进制文件也好,还是文本文件也好,都是一连串 的0和1,但是打开方式不同,对于这些0和1的处理也就不同。如果按照文本方式打开,在 打开的时候会进行translate,将每个字节转换成ASCII码,而以按照二进制方式打开的话, 则不会进行

2、任何的translate;最后就是文本文件和二进制文件在编辑的时候,使用的方式也 是不同的。譬如,你在记事本中进行文本编辑的时候,你进行编辑的最小单位是字节(byte); 而对二进制文件进行编辑的话,最小单位则是位(bit),当然我们都不会直接通过手工的方式对 二进制文件进行编辑了。 从文件编码的方式来看,文件可分为ASCII码文件和二进制码文件两种: ASCII文件也称为文本文件,这种文件在磁盘中存放时每个字符对应一个字节,用于存放对应 的ASCII码。例如,数5678的存储形式为: ASCII码: 00110101 00110110 00110111 00111000 十进制码: 5 6

3、7 8 共占用4个字节。ASCII码文件可在屏幕上按字符显示,例如源程序文件就是ASCII文件,用 DOS命令TYPE可显示文件的内容。由于是按字符显示,因此能读懂文件内容。 二进制文件是按二进制的编码方式来存放文件的。例如,数5678的存储形式为:00010110 00101110 只占二个字节。二进制文件虽然也可在屏幕上显示,但其内容无法读懂。C系统在 处理这些文件时,并不区分类型,都看成是字符流,按字节进行处理。输入输出字符流的开始 和结束只由程序控制而不受物理符号(如回车符)的控制。因此也把这种文件称作“流式文件”。2. 文本模式(textmode)和二进制模式(binarymode)

4、有什么区别? 流可以分为两种类型:文本流和二进制流。文本流是解释性的,最长可达255个字符,其中回 车/换行将被转换为换行符“n”,(如果以“文本“方式打开一个文件,那么在读字符的时候, 系统会把所有的“rn“序列转成“n“,在写入时把“n“转成“rn“ )。二进制流是非解释性的, 一次处理一个字符,并且不转换字符。 注: n一般会操作系统被翻译成“行的结束“,即LF(Line-Feed)r会被翻译成“回车“,即CR(Cariage-Return)对于文本文件的新行,在UNIX上,一般用n(LF)来表示,Mac上用r(CR)来表示, Windows上是用nr(CR-LF)来表示。 通常,文本流

5、用来读写标准的文本文件,或者将字符输出到屏幕或打印机,或者接受键盘 的输入;而二进制流用来读写二进制文件(例如图形或字处理文档),或者读取鼠标输入,或者 读写调制解调器。如果用文本方式打开二进制文件,会把“0D 0A”自动变换成“n”来存在 内存中。写入的时候反向处理。而二进制方式打开的话,就不会有这个过程。但是, Unicode/UTF/UCS格式的文件,必须用二进制方式打开和读写。 - - 上述基础其实大可以略过,简言之,对用户来说:在 matlab 中存储成为二进制还是文本文件 取决于fopen的方式,如果用wt,则存储为文本文件,这样用记事本打开就可以正常显示了; 如果用w则存储为二进

6、制文件,这样用记事本打开会出现小黑方块,要正常显示的话,可以用 写字板或UltraEdit等工具打开。 二. Matlab的I/O文件操作使用技巧和总结: 1. Matlab 支持的I/O文件(对应“取/存”操作)类型:(所有文件I/O程序不 需要特殊的工具箱) http:/ (注:从上表可以看到,matlab不支持doc格式的文档存取(因为doc文档包含很多格式控制 符),请改用txt或者dat格式) 2. Matlab 的I/O文件指南: http:/ 以下是部分对应的中文译文: -转- - 本技术支持指南主要处理:ASCII, binary, and MAT files. 要得到MATL

7、AB中可用来读写各种文件格式的完全函数列表,可以键入以下命令: help iofun MATLAB中有两种文件I/O程序:high level and low level. High level routines: 包括现成的函数,可以用来读写特殊格式的数据,并且只需要少量的编 程。 Low level routines: 可以更加灵活的完成相对特殊的任务,需要较多的额外编程。 High level routines 包括现成的函数,可以用来读写特殊格式的数据,并且只需要少量的编 程。举个例子,如果你有一个包含数值和字母的文本文件(text file)想导入MATLAB,你可以调 用一些low

8、 level routines自己写一个函数,或者是简单的用TEXTREAD函数。 使用high level routines的关键是:文件必须是相似的(homogeneous),换句话说,文件必 须有一致的格式。下面的段落描述一些high level file I/O routines并给出一些例子帮助理 解概念。 LOAD/SAVE 主要的high level file I/O routines 是LOAD 和 SAVE函数。LOAD 可以读MAT-file data或者用空格间隔的格式相似的ASCII data. SAVE可以将MATLAB变量写 入MAT-file格式或者空格间隔的AS

9、CII data。大多数情况下,语法相当简单。下面的例子用 到数值由空格间隔的ASCII file sample_file.txt : 1 5 4 16 8 5 43 2 6 8 6 8 4 32 1 90 7 8 7 6 5 9 81 2 3 Example: 用 LOAD and SAVE 读写数据CODE: % Load the file to the matrix, M : M = load(sample_file.txt) % Add 5 to M : M = M +5 % Save M to a .mat file called sample_file_plus5.mat: sav

10、e sample_file_plus5 M % Save M to an ASCII .txt file called sample_file_plus5.txt : save sample_file_plus5.txt M -ascii UIGETFILE/UIPUTFILE UIGETFILE/UIPUTFILE是基于图形用户界面(GUI)的。会弹出对话框,列出当前目录的文件和 目录,提示你选择一个文件。UIGETFILE让你选择一个文件来写(类似Windows 另存为选 项?)。用UIGETFILE,可以选择已存在的文件改写,也可以输入新的文件名。两个函数的返 回值是所选文件名和路径。

11、Example: 用 UIGETFILE 从当前目录选择一个 M-file CODE: % This command lists all the M-files in the current directory and % returns the name and path of the selected file fname,pname = uigetfile(*.m,Sample Dialog Box) 注意: UIGETFILE 一次只能选择一个文件。 UIIMPORT/IMPORTDATA UIIMPORT是一个功能强大,易于使用的基于GUI的high level routine,用于

12、读complex data files。文件也必须是homogeneous。 IMPORTDATA形成UIIMPORT的功能,不打开GUI。可以将IMPORTDATA用于函数或者脚本中,因 为在函数或者脚本中基于GUI的文件导入机制并不理想。下面的例子用到包含几行文件头和文 本、数值数据的文件sample_file2.txt : This is a file header. This is file is an example. col1 col2 col3 col4 A 1 4 612.000 B 1 4 613.000 C 1 4 614.000D 1 4 615.000 Example:

13、 Using IMPORTDATA to read in a file with headers, text, and numeric data CODE: % This reads in the file sample_file2.txt and creates a % structure D that contains both data and text data. % Note the IMPORTDATA command specifies a white space % as the delimiter of the file, but IMPORTDATA can usually

14、 % detect this on its own D = importdata(sample_file2.txt,) % 原文有误? D = importdata(sample_file2.txt) 可以通过访问结构D的数据和文本域,来看结构D中的真实值,例如输入: data = D.data text = D.textdata 可以用UIIMPORT读同一个文件并得到同样的结构. 注意: 对于 ASCII data, 你必须检验导入向导正确的识别了列分隔符。 TEXTREAD/STRREADTEXTREAD 是一个强大的动态high level routine,设计用来读ASCII格式的文本和/或数值数 据文件。STRREAD除是从字符串而不是文件读以外,类似于TEXTREAD。 两个函数可以用许多参数来改变其具体的工作方式,他们返回读入指定输出的数据。他们有效 的提供给你一个 “两全其美”的方法,因为他们可以用一个命令读入混合的ASCII和数值数据(high level routines的做法),并且你可以改变他们以匹配你特定的应用(如同low level routines做 到的)。例子: CODE: Examp

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 行业资料 > 其它行业文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号