资讯详情

二进制文件和文本文件到底有什么不同?(二)

1)文本文件:这类文件是文本ASCII存储在计算机中的代码形式。它是基于"行"一种基本结构的信息组织和存储模式。 2)二进制文件:此类文件以文本二进制的形式存储在计算机中。用户通常不能直接理解它们,只能通过相应的软件显示它们。二进制文件一般为可执行程序、图形、图像、声音等。

C 标准库提供基于输入/输出流机制的文件操作,称为文件流(File Stream)。打开文件时,可以根据二进制或文本的参数制定参数。

然而,与你的想象不同的是,这里的二进制或文本与文件的格式无关,而是文件流操作中的数据表达。

文本模式和二进制模式最大的区别在于文本模式对‘\n对换行符的理解不同,在DOS在平台下,字符将展开<CR>< LF>两个控制字符(相当于两个控制字符)"\r\n"),在ASCII字符集下是0DH,0AH,而在UNIX只是在平台下<LF>,不会展开。在二进制模式下,无论是什么平台,‘\n都是准确的<LF>。

而类似于一个数学上的数字128,会在文件中以什么样的格式存储,是以数字形式存储(80H),对应的可读文本(‘1’、‘2’、‘8’),与文件流的打开方式无关。

在C 在文件流中,使用的术语称为格式输入输出操作和非格式操作,前者是<<和>>运算符按可读文本存储数字,后者为get/put直接存储数字格式的成员函数。

一、文本文件和二进制文件的定义

众所周知,计算机的存储在物理上是二进制的,以文本文件和二进制文件的区别不是物理上的,而是逻辑上的。两者在编码层次上只有差异。简单地说,文本文件是基于字符编码的文件,常见的编码是ASCII编码,UNICODE编码等等。二进制文件是基于值编码的文件。您可以根据具体应用程序指定值的含义(此过程可视为自定义编码)。

从上面可以看出,文本文件基本上是长编码(也有非长编码,如UTF-8)。而二进制文件可以看作是变长编码,因为是值编码,多少比特代表一个值,完全由你决定。大家可能对BMP文件比较熟悉,以它为例,它的头是一个相对固定长度的文件头信息,前2字节用来记录文件BMP格式,下8个字节用于记录文件长度,下4个字节用于记录bmp文件头的长度。

二、存取文本文件和二进制文件

打开文本工具的过程是什么?以记事本为例,它首先阅读文件物理对应的二进制比特流,然后根据您选择的解码方法解释流,然后显示解释结果。一般来说,你选择的解码方法是ASCII码形式(ASCII代码的一个字符是8个比特)。接下来,8个比特和8个比特来解释文件流。例如,对于这样的文件流"01000000_01000001_01000010_01000011"(下划线_第一个8比特‘0100000’是为了增强手动添加的可读性)ASCII如果代码解码,对应的字符是字符‘’A同理,其他3个8比特可以分别解码为‘’BCD'',即文件流可以解释为ABCD然后记事本就把这个ABCD显示在屏幕上。

事实上,世界上任何与其他东西交流的东西都有既定的协议和编码。人与人之间通过文字接触,汉字妈妈代表生你的人,这是一个既定的代码。但是,注意到这种情况,汉字妈妈可能是你在日语中生下的人,所以中国人在A和日本B之间用妈妈这个词交流是正常的。用记事本打开二进制文件类似于上述情况。记事本按既定字符编码,无论打开什么文件(如ASCII码),所以当他打开二进制文件时,乱码也是必然的。解码与译码不对应。例如,文件流_00000000_00000000_二进制文件中可能对应于四字节的整数int 1.在记事本上解释"NULL_NULL_NULL_SOH"这四个控制符。

文本文件的存储和阅读基本上是一个逆转过程。二进制文件的访问显然与文本文件的访问相似,但编辑/解码方法不同,不再描述。

三、文本文件和二进制文件的优缺点

因为文本文件和二进制文件的区别只是编码上的区别,所以它们的优缺点是编码的优缺点,这本书更清楚。一般认为,文本文件编码是基于字符长度,更容易翻译;二进制文件编码变长,灵活,存储利用率高,难以翻译(不同的二进制文件格式,翻译方法不同)。至于空间利用率,想想看,二进制文件甚至可以用一个比特来代表一个意思(位操作),而文本文件的任何意思至少是一个字符。

在windows下面,文本文件不一定是一定的ASCII因为ASCII代码只能表示128的标志。打开一个txt文档,然后另存为,有个选项是编码,可以选择存贮格式,一般来说UTF-8编码格式的兼容性更好.而二进制计算机的原始语言,不存储兼容性. 许多书还认为文本文件的可读性更好,存储需要转换时间(读写编码),而二进制文件的可读性较差,存储没有转换时间(读写不编解码,直接写值)。这里的可读性是从软件用户的角度来看的,因为我们几乎可以使用通用的记事本工具浏览所有的文本文件,所以说文本文件可读性好;而读写一个具体的二进制文件需要一个具体的文件解码器,所以说二进制文件可读性差,比如读BMP读图软件必须用于文件。

这里的存储转换时间应该从编程的角度来看,因为一些操作系统,如windows需要转换回车换行符(将)\n换成\r\n因此,文件读写时,操作系统需要逐个检查当前字符是否为‘’\n''或''\r\n'').这是存储转换Linux当然,在两个不同的操作系统上共享文件时,不需要操作系统。Linux系统和Windows系统共享文本文件)。我将在下一篇文章中讨论如何进行这个转换《Linux文本文件与Windows文本文件间的转换》给出^_^

四、C文本读写和二进制读写

应该说,C的文本读写和二进制读写是编程层面的问题,与具体的操作系统有关。因此,文本读写的文件必须是文本文件,二进制读写的文件必须是二进制文件"这种观点是错误的。下面的描述没有明确指出操作系统的类型,而是暗示windows.

C文本方读写和二进制读写的区别只体现在回车换行符的处理上。文本写作时,每次遇到‘’\n''(0AH换行符),用‘’代替它\r\n''(0D0AH,回车换行),然后写入文件;当文本读取时,每次遇到‘’\r\n把它变成‘’\n'',然后送到读缓冲区,因为文本方式有‘’\n\r\n转换之间存在转换时间。二进制读写时,没有转换,直接将缓冲区数据写入文件。

一般来说,从编程的角度来看,C中文本或二进制读写是缓冲区与文件中二进制流的交互,但文本读写时有回车换行的转换。因此,在缓冲区写作时,没有换行符\n''(0AH),文本写作的结果与二进制写相同。同样,当文件中没有‘’时\r\n''(0DH0AH)时,文本阅读的结果与二进制阅读相同。

五、实例

C文本读写和二进制读写 应该说,C的文本读写和二进制读写是编程层面的问题,与具体的操作系统有关。因此,文本读写的文件必须是文本文件,二进制读写的文件必须是二进制文件"这种观点是错误的。下面的描述没有明确指出操作系统的类型,而是暗示windows.

C文本方读写和二进制读写的区别只体现在回车换行符的处理上。文本写作时,每次遇到‘’\n''(0AH换行符),用‘’代替它\r \n''(0D0AH,回车换行),然后写入文件;当文本读取时,每次遇到‘’\r\n把它变成‘’\n'',然后送到读缓冲区。二进制读写时,没有任何转换,直接将缓冲区数据写入文件。 “Ab123\r\n" (41 62 31 32 33 0D 0A)的文件,

pf1 = fopen("f:\\1.txt","r");// 或者pf1 = fopen("f:\\1.txt","rb"); for(int i=0;i <6;i  ) {    fread(&a[i],1,1,pf1);    printf("%0X ",a[i]); } fclose(pf1);//关闭文件

结果分别为: 41 62 31 32 33 0A 和 41 62 31 32 33 0D 5678的存储形式如下:ASCII码: 00110101 00110110 00110111 00111000 (四字节) 5678的存储形式如下:二进制: 00010110 00101110 (两个字节) 二进制文件和文本文件的唯一区别是前者含有一些非标准输出ASCII码。0x01是非标准输出ASCII码,

0x61是标准输出ASCII码。)

--------------------------------------------------转---------------------------------------------------- 文件被视为字节(byte) 组成的, 所以文本文件中每个字节的最高位是0,也就是说,文本文件使用一个字节中的七个来表示所有信息,而二进制文件使用字节中的所有位置。这就是两者的区别;然后,第二个问题是文件按照文本或二进制打开。两者有什么区别?事实上,无论是二进制文件还是文本文件,一连串的0和1,但是打开方式不同,对于这些0和1的处理也就不同。如果按照文本方式打开,在打开的时候会进行translate,将每个字节转换成ASCII码,而以按照二进制方式打开的话,则不会进行任何的translate;最后就是文本文件和二进制文件在编辑的时候,使用的方式也是不同的。譬如,你在记事本中进行文本编辑的时候,你进行编辑的最小单位是字节(byte);而对二进制文件进行编辑的话,最小单位则是位(bit),当然我们都不会直接通过手工的方式对二进制文件进行编辑了。 从文件编码的方式来看,文件可分为ASCII码文件和二进制码文件两种: ASCII文件也称为文本文件,这种文件在磁盘中存放时每个字符对应一个字节,用于存放对应的ASCII码。例如,数5678的存储形式为: ASCII码: 00110101 00110110 00110111 00111000 ↓  ↓      ↓   ↓ 十进制码: 5     6   7      8 共占用4个字节。ASCII码文件可在屏幕上按字符显示,例如源程序文件就是ASCII文件,用DOS命令TYPE可显示文件的内容。由于是按字符显示,因此能读懂文件内容。 二进制文件是按二进制的编码方式来存放文件的。例如,数5678的存储形式为:00010110 00101110 只占二个字节。二进制文件虽然也可在屏幕上显示,但其内容无法读懂。C系统在处理这些文件时,并不区分类型,都看成是字符流,按字节进行处理。输入输出字符流的开始和结束只由程序控制而不受物理符号(如回车符)的控制。因此也把这种文件称作“流式文件”。 流可以分为两种类型:文本流和二进制流。文本流是解释性的,最长可达255个字符,其中回车/换行将被转换为换行符“\n”,(如果以"文本"方式打开一个文件,那么在读字符的时候,系统会把所有的"\r\n"序列转成"\n",在写入时把"\n"转成"\r\n" )。二进制流是非解释性的,一次处理一个字符,并且不转换字符。 注:

\n一般会操作系统被翻译成"行的结束",即LF(Line-Feed) \r会被翻译成"回车",即CR(Cariage-Return) 对于文本文件的新行,在UNIX上,一般用\n(LF)来表示,Mac上用\r(CR)来表示, Windows上是用\n\r(CR-LF)来表示。 通常,文本流用来读写标准的文本文件,或者将字符输出到屏幕或打印机,或者接受键盘的输入;而二进制流用来读写二进制文件(例如图形或字处理文档),或者读取鼠标输入,或者读写调制解调器。如果用文本方式打开二进制文件,会把“0D 0A”自动变换成“\n”来存在内存中。写入的时候反向处理。而二进制方式打开的话,就不会有这个过程。但是,Unicode/UTF/UCS格式的文件,必须用二进制方式打开和读写。

--------------------------------------------------------------------------------------------------------- 上述基础其实大可以略过,在 matlab 中存储成为二进制还是文本文件取决于fopen的方式,如果用wt,则存储为文本文件,这样用记事本打开就可以正常显示了;如果用w则存储为二进制文件,这样用记事本打开会出现小黑方块,要正常显示的话,可以用写字板或UltraEdit等工具打开。(所有文件I/O程序不需要特殊的工具箱)Supported File Formats for Import and Export- MATLAB & Simulink (注:从上表可以看到,matlab不支持doc格式的文档存取(因为doc文档包含很多格式控制符),请改用txt或者dat格式)Supported File Formats for Import and Export- MATLAB & Simulink 以下是部分对应的中文译文: --------------------------------------------------------------转---------------------------------------- 本技术支持指南主要处理:ASCII, binary, and MAT files. 要得到MATLAB中可用来读写各种文件格式的完全函数列表,可以键入以下命令: help iofun 包括现成的函数,可以用来读写特殊格式的数据,并且只需要少量的编程。 可以更加灵活的完成相对特殊的任务,需要较多的额外编程。  

High level routines 包括现成的函数,可以用来读写特殊格式的数据,并且只需要少量的编程。

举个例子,如果你有一个包含数值和字母的文本文件(text file)想导入MATLAB,你可以调用一些low level routines自己写一个函数,或者是简单的用TEXTREAD函数。

换句话说,文件必须有一致的格式。下面的段落描述一些high level file I/O routines并给出一些例子帮助理解概念。

主要的high level file I/O routines 是LOAD 和 SAVE函数。LOAD 可以读MAT-file data或者用空格间隔的格式相似的ASCII data. SAVE可以将MATLAB变量写入MAT-file格式或者空格间隔的ASCII 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 读写数据

% 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':
save 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是基于图形用户界面(GUI)的。会弹出对话框,列出当前目录的文件和目录,提示你选择一个文件。UIGETFILE让你选择一个文件来写(类似Windows ‘另存为’选项?)。用UIGETFILE,可以选择已存在的文件改写,也可以输入新的文件名。两个函数的返回值是所选文件名和路径。

Example: 用 UIGETFILE 从当前目录选择一个 M-file

% 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是一个功能强大,易于使用的基于GUI的high level routine,用于读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.000

D 1 4 615.000

Example: 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 % 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 是一个强大的动态high level routine,设计用来读ASCII格式的文本和/或数值数据文件。STRREAD除是从字符串而不是文件读以外,类似于TEXTREAD。

两个函数可以用许多参数来改变其具体的工作方式,他们返回读入指定输出的数据。他们有效的提供给你一个 “两全其美”的方法,因为他们可以用一个命令读入混合的ASCII和数值数据(high level routines的做法),并且你可以改变他们以匹配你特定的应用(如同low level routines做到的)。例子:

CODE: Example 1: Using TEXTREAD to read in an entire file into a cell array % This command reads in the file fft.m into the cell array, file file = textread('fft.m','%s','delimiter','\n','whitespace',''); CODE: Example 2: Using STRREAD to read the words in a line % This command uses the cell array created in Example 1 to % read in each word of line 28 in 'file' to a cell array, words words = strread(file{28},'%s','delimiter','')

CODE: Example 3: Using TEXTREAD to read in text and numeric data from a file with headers % This command skips the 2 header lines at the top of the file % and reads in each column to the 4 specified outputs [c1 c2 c3 c4] = textread('sample_file2.txt','%s %s %s %s','headerlines',2)

CODE: Example 4: Using TEXTREAD to read in specific rows of text and numeric data from a file % This command reads in rows B and C of the file. The 'headerlines' % property is used to move down to the desired starting row and the % read operation is performed 2 times [c1 c2 c3 c4] = textread('sample_file2.txt',... '%s %s %s %s',2,'headerlines',4) CODE: Example 5: Using TEXTREAD to read in only the numeric data from a file containing text and numbers % This command reads in only the numeric data in the file. The % 'headerlines' property is used to move down to the first row % of interest and the first column of text is ignored with the % '*' operator [c2 c3 c4] = textread('sample_file2.txt','%*s %d %d %f','headerlines',3)  

DLMREAD 和 DLMWRITE函数能够读写分隔的ASCII data,而不是用low level routines。他们比low level routines容易使用,Low level routines用几行代码实现的功能可以用DLMREAD/DLMWRITE简化成一行。

CSVREAD用来读分隔符是逗号的文件,是DLMREAD的特殊情况。当读空格和Tab分隔的电子数据表文件时,DLMREAD特别有用。以'sample_file.txt'为例:

CODE: Example 1: Using DLMREAD to read in a file with headers, text, and numeric data % This reads in the file 'sample_file2.txt' and creates a matrix, D, % with the numeric data this command specifies a white space as the % delimiter of the file D = dlmread('sample_file.txt','') CODE: Example 2: Using DLMREAD to extract the first 3 columns of the last 3 rows % This reads in the first 3 columns of the last 3 rows of % the data file 'sample_file.txt'into the matrix, D_partial. % 读文件 'sample_file.txt' 前3列后3行,到矩阵D_partial. D_partial = dlmread('sample_file.txt','',[2 0 4 2]) CODE: Example 3: Using DLMWRITE to write a comma delimited file % This creates a file called 'partialD.txt' that consists of % the first 3 columns of the last 3 rows of data where each % element is separated by a comma dlmwrite('partialD.txt',D_partial,',')  

注意: 保证DLMREAD and DLMWRITE指定范围的指标从0开始,而不是从1开始。

WK1READ 用来读Lotus123 电子数据表文件的数据;WK1WRITE用来写矩阵到Lotus123 电子数据表文件。

XLSREAD用来读Excel的数值和文本数据。

--------------------------------------------------------------------------------------------------------- Matlab网站用两个例子非常详尽地介绍了各个命令的基本用法,实际中,面对手头上的数据,如何选用合适的命令呢?以下结合几个示例给出一些总结,大家举一反三就可以了: CODE: 0 3866.162 2198.938 141.140 1 3741.139 2208.475 141.252 2 3866.200 2198.936 141.156 3 3678.048 2199.191 141.230 4 3685.453 2213.726 141.261 5 3728.769 2212.433 141.277 6 3738.785 2214.381 141.256 7 3728.759 2214.261 141.228 8 3748.886 2214.299 141.243 9 3748.935 2212.417 141.253 10 3733.612 2226.653 141.236 11 3733.583 2229.248 141.223 12 3729.229 2229.118 141.186:对于这个txt文件,由于各行列数相同,故简单地使用load,importdata均可。 CODE: CH0 CH1 CH2 CH3 0.000123 0.000325 0.000378 0.000598 0.000986 0.000256 0.000245 0.000698:由于是记录的形式,因此各行列数必相同(缺少部分列时请自行在文件中补上 Inf 或 NaN),故直接使用 importdata 便可。:这个文件有4列,但前6行是文字说明,4列数字是从第8行开始的.现在我想把这个文件的前2列和文字说明提出来组成一个新的dat文件 CODE: Group 2 12.02.2006 Limei Samples of datas: 50000 CH0 CH1 CH2 CH3 0.000123 0.000325 0.000378 0.000598 0.000986 0.000256 0.000245 0.000698 CODE: Group 2 12.02.2006 Limei Samples of datas: 50000 CH0 CH1 0.000123 0.000325 0.000986 0.000256:由于注释中含有独立的数字串,且注释部分没有明显的格式,这时候用importdata, load等高级命令直接读取会失败,用 textread, dlmwrite 等格式化命令也不太合适,因此只能使用低级命令进行读取。(当然了,可以跳过注释部分直接用高级命令读取数据,即:[a b c d] = textread(filename,'%f %f %f %f','headerlines',4); )。一个简单的、非通用的包含注释的读取方法如下: -------------------------------------转 --------------------------------------------------------------------------------------- CODE: clc;clear; fid = fopen('exp.txt', 'r'); fid_n=fopen('ex.dat','w'); while ~feof(fid) tline=fgetl(fid); if ~isempty(tline) if double(tline(1))>=48 && double(tline(1))<=57 %数值开始 a=strread(tline); a(3:4)=[]; fprintf(fid_n,'%f %f\n',a); clear a; elseif double(tline(1))==67 %字母C开始 [b1,b2,b3,b4]=strread(tline,'%s %s %s %s'); b=[b1{1},' ',b2{1}]; fprintf(fid_n,'%s\n',b); clear b b1 b2 b3 b4; else fprintf(fid_n,'%s\n',tline); end else fprintf(fid_n,'%s\n',tline); end end fclose(fid); fclose(fid_n); --------------------------------------------------------------------------------- CODE: 你好 abc 欢迎来到 我们 振动论坛 vib.hit.edu.cn 1 11 111 1111 2 22 222 2222 3 33 333 3333 4 44 444 4444 5 55 555 5555直接用 importdata 便可有时候注释中含有独立的数字串也可以 importdata 成功,不过得到的结果有可能不正确,建议这时候使用第3种情形的读取方式。 对此当然只能自己编程,举例:: CODE: 1 11 111 1111 你好 2 22 222 2222 欢迎来到 3 33 333 3333 振动论坛 4 44 444 4444 vib.hit.edu.cn 5 55 555 5555 --------------------------------------------转-------------------------------------- CODE: function [data]=distilldata(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) % 判断是否空行 [m,n]=size(tline); flag=1; for i=1:n %判断一行中有没有字符(+-.Ee和空格键除外) if ~(tline(i)==' '|tline(i)=='-'|tline(i)=='.'|tline(i)=='E'... |tline(i)=='e'|tline(i)=='+'... |(double(tline(i))>=48&&double(tline(i))<=57)) flag=0; break; end end if flag==1 % 如果是数字行,把此行数据写入文件 fprintf(fidtmp,'%s\n',tline); end end end fclose(fidin); fclose(fidtmp); data=textread(tmpfile); delete(tmpfile); --------------------------------------------------------------------------------------------------------- 另外,如果要求不高,也可以使用 textread 函数跳过注释部分进行读取,不过前提是需要事先知道文件内容的结构(即哪行是数据、哪行是注释) CODE: 0 + 47038.7 1.05 09:26:07 C 2 + 46477.7 1.03 09:28:38 C 4 + 44865.7 1.04 09:28:48 C 6 + 41786.4 1.03 09:28:56 C 8 + 39896.0 0.97 09:29:03 C 10 + 37518.4 0.93 09:29:15 C 12 + 35858.5 0.92 09:29:30 C 14 + 46105.0 1.03 09:30:21 C 16 + 46168.6 6.89 09:30:30 C 18 + 48672.3 4.33 09:30:40 C 20 + 49565.7 0.49 09:30:48 C 22 + 49580.7 0.53 09:30:55 C 24 + 49602.3 0.84 09:31:03 C 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 是错误且无意义的!

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}便可得到各文件名。

假设每个文件对应的数据是m*n的,则: CODE: k = length(filename); Data = zeros(m,n,k); for ii = 1:k Data(:,:,ii) = yourreadstyle(filename{ii}); %yourreadstyle是对应的文件读取方式的函数 end 假设每个文件对应的数据是m*n的,则以上述第二种文件名读取方法为例: CODE: k = length(filename); for ii = 1:k D = yourreadstyle(filename{ii}); eval([‘Data_’, num2str(ii), ‘ = D;’]); end 文件名为 abc00001,abc00002,... abc00009,abc00010,... abc00099,abc00100,...abc00879. 准备把这些文件名给放到一个数组里面去。 CODE: a=cell(879,1); for k=1:879 a{k} = sprintf('%.5d',k); end:可以利用正则表达式来处理,使之通用性较强。例如使用以下代码可以自动处理上面提到了例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) 可以考虑使用循环分批读取(特别是在各数据是独立的时候),或者使用稀疏矩阵来实现(对此可以参阅本版精华贴: [原创]提高matlab运行速度和节省空间的一点心得(之三))。另外,也可参考《深入浅出MATLAB 7_X混合编程》一书第一章 CODE: f = fopen('yourfilename.txt','rt'); % t 属性根据需要可省略 x = fread(f,'*char'); fclose(f); 如果写入的时候简单一点,则可以采用以下方式,不过读取的时候比较麻烦: 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);

标签: 振动变送器wt0180

锐单商城拥有海量元器件数据手册IC替代型号,打造 电子元器件IC百科大全!

锐单商城 - 一站式电子元器件采购平台