国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書(shū)等14項(xiàng)超值服

開(kāi)通VIP
使用文本文件
使用文本文件(.txt)進(jìn)行數(shù)據(jù)存取的技巧總結(jié)

由于本帖內(nèi)容較多,部分轉(zhuǎn)自他人的心得,因此,凡轉(zhuǎn)貼的地方僅用“----轉(zhuǎn)----”標(biāo)注,原作者略去,在此對(duì)所有原作者表示感謝!

特別說(shuō)明:由于大家在 I/O 存取上以 txt 文件為主,且讀取比存儲(chǔ)更麻煩(存儲(chǔ)的話 fwrite, fprintf 基本夠用),因此下面的討論主要集中在“txt 文件的讀取”上。除了標(biāo)注了“轉(zhuǎn)”之外,其余心得均出于本人經(jīng)驗(yàn)之結(jié)果,歡迎大家指正、補(bǔ)充。

一. 基本知識(shí):
--------------------------------------------------轉(zhuǎn)----------------------------------------------------
1. 二進(jìn)制文件與文本文件的區(qū)別:
將文件看作是由一個(gè)一個(gè)字節(jié)(byte) 組成的, 那么文本文件中的每個(gè)字節(jié)的最高位都是0,也就是說(shuō)文本文件使用了一個(gè)字節(jié)中的七位來(lái)表示所有的信息,而二進(jìn)制文件則是將字節(jié)中的所有位都用上了。這就是兩者的區(qū)別;接著,第二個(gè)問(wèn)題就是文件按照文本方式或者二進(jìn)制方式打開(kāi),兩者會(huì)有什么不同呢?其實(shí)不管是二進(jìn)制文件也好,還是文本文件也好,都是一連串的0和1,但是打開(kāi)方式不同,對(duì)于這些0和1的處理也就不同。如果按照文本方式打開(kāi),在打開(kāi)的時(shí)候會(huì)進(jìn)行translate,將每個(gè)字節(jié)轉(zhuǎn)換成ASCII碼,而以按照二進(jìn)制方式打開(kāi)的話,則不會(huì)進(jìn)行任何的translate;最后就是文本文件和二進(jìn)制文件在編輯的時(shí)候,使用的方式也是不同的。譬如,你在記事本中進(jìn)行文本編輯的時(shí)候,你進(jìn)行編輯的最小單位是字節(jié)(byte);而對(duì)二進(jìn)制文件進(jìn)行編輯的話,最小單位則是位(bit),當(dāng)然我們都不會(huì)直接通過(guò)手工的方式對(duì)二進(jìn)制文件進(jìn)行編輯了。

從文件編碼的方式來(lái)看,文件可分為ASCII碼文件和二進(jìn)制碼文件兩種:
ASCII文件也稱為文本文件,這種文件在磁盤中存放時(shí)每個(gè)字符對(duì)應(yīng)一個(gè)字節(jié),用于存放對(duì)應(yīng)的ASCII碼。例如,數(shù)5678的存儲(chǔ)形式為:   
   ASCII碼: 00110101   00110110   00110111   00111000   
                         ↓              ↓        ↓            ↓
  十進(jìn)制碼:       5     6            7       8   

共占用4個(gè)字節(jié)。ASCII碼文件可在屏幕上按字符顯示,例如源程序文件就是ASCII文件,用DOS命令TYPE可顯示文件的內(nèi)容。由于是按字符顯示,因此能讀懂文件內(nèi)容。

二進(jìn)制文件是按二進(jìn)制的編碼方式來(lái)存放文件的。例如,數(shù)5678的存儲(chǔ)形式為:00010110   00101110 只占二個(gè)字節(jié)。二進(jìn)制文件雖然也可在屏幕上顯示,但其內(nèi)容無(wú)法讀懂。C系統(tǒng)在處理這些文件時(shí),并不區(qū)分類型,都看成是字符流,按字節(jié)進(jìn)行處理。輸入輸出字符流的開(kāi)始和結(jié)束只由程序控制而不受物理符號(hào)(如回車符)的控制。因此也把這種文件稱作“流式文件”。  

2. 文本模式(textmode)和二進(jìn)制模式(binarymode)有什么區(qū)別?   

流可以分為兩種類型:文本流和二進(jìn)制流。文本流是解釋性的,最長(zhǎng)可達(dá)255個(gè)字符,其中回車/換行將被轉(zhuǎn)換為換行符“\n”,(如果以"文本"方式打開(kāi)一個(gè)文件,那么在讀字符的時(shí)候,系統(tǒng)會(huì)把所有的"\r\n"序列轉(zhuǎn)成"\n",在寫入時(shí)把"\n"轉(zhuǎn)成"\r\n" )。二進(jìn)制流是非解釋性的,一次處理一個(gè)字符,并且不轉(zhuǎn)換字符。


注:  

      \n一般會(huì)操作系統(tǒng)被翻譯成"行的結(jié)束",即LF(Line-Feed)
      \r會(huì)被翻譯成"回車",即CR(Cariage-Return)
      對(duì)于文本文件的新行,在UNIX上,一般用\n(LF)來(lái)表示,Mac上用\r(CR)來(lái)表示,
      Windows上是用\n\r(CR-LF)來(lái)表示。        
         
    通常,文本流用來(lái)讀寫標(biāo)準(zhǔn)的文本文件,或者將字符輸出到屏幕或打印機(jī),或者接受鍵盤的輸入;而二進(jìn)制流用來(lái)讀寫二進(jìn)制文件(例如圖形或字處理文檔),或者讀取鼠標(biāo)輸入,或者讀寫調(diào)制解調(diào)器。如果用文本方式打開(kāi)二進(jìn)制文件,會(huì)把“0D   0A”自動(dòng)變換成“\n”來(lái)存在內(nèi)存中。寫入的時(shí)候反向處理。而二進(jìn)制方式打開(kāi)的話,就不會(huì)有這個(gè)過(guò)程。但是,Unicode/UTF/UCS格式的文件,必須用二進(jìn)制方式打開(kāi)和讀寫。

---------------------------------------------------------------------------------------------------------

上述基礎(chǔ)其實(shí)大可以略過(guò),簡(jiǎn)言之,對(duì)用戶來(lái)說(shuō):在 matlab 中存儲(chǔ)成為二進(jìn)制還是文本文件取決于fopen的方式,如果用wt,則存儲(chǔ)為文本文件,這樣用記事本打開(kāi)就可以正常顯示了;如果用w則存儲(chǔ)為二進(jìn)制文件,這樣用記事本打開(kāi)會(huì)出現(xiàn)小黑方塊,要正常顯示的話,可以用寫字板或UltraEdit等工具打開(kāi)。

二. Matlab的I/O文件操作使用技巧和總結(jié):


1. Matlab 支持的I/O文件(對(duì)應(yīng)“取/存”操作)類型:(所有文件I/O程序不需要特殊的工具箱
http://www.mathworks.com/support/tech-notes/1100/1102.html

(注:從上表可以看到,matlab不支持doc格式的文檔存?。ㄒ?yàn)閐oc文檔包含很多格式控制符),請(qǐng)改用txt或者dat格式)

2. Matlab 的I/O文件指南:
http://www.mathworks.com/support/tech-notes/1600/1602.html


以下是部分對(duì)應(yīng)的中文譯文:
--------------------------------------------------------------轉(zhuǎn)----------------------------------------
本技術(shù)支持指南主要處理:ASCII, binary, and MAT files.
要得到MATLAB中可用來(lái)讀寫各種文件格式的完全函數(shù)列表,可以鍵入以下命令:
help iofun

MATLAB中有兩種文件I/O程序:high level and low level.
High level routines: 包括現(xiàn)成的函數(shù),可以用來(lái)讀寫特殊格式的數(shù)據(jù),并且只需要少量的編程。
Low level routines: 可以更加靈活的完成相對(duì)特殊的任務(wù),需要較多的額外編程。


High level routines 包括現(xiàn)成的函數(shù),可以用來(lái)讀寫特殊格式的數(shù)據(jù),并且只需要少量的編程。


舉個(gè)例子,如果你有一個(gè)包含數(shù)值和字母的文本文件(text file)想導(dǎo)入MATLAB,你可以調(diào)用一些low level routines自己寫一個(gè)函數(shù),或者是簡(jiǎn)單的用TEXTREAD函數(shù)。


使用high level routines的關(guān)鍵是:文件必須是相似的(homogeneous),換句話說(shuō),文件必須有一致的格式。下面的段落描述一些high level file I/O routines并給出一些例子幫助理解概念。


LOAD/SAVE


主要的high level file I/O routines 是LOADSAVE函數(shù)。LOAD
可以讀MAT-file data或者用空格間隔的格式相似的ASCII data. SAVE可以將MATLAB變量寫入MAT-file格式或者空格間隔的ASCII data。大多數(shù)情況下,語(yǔ)法相當(dāng)簡(jiǎn)單。下面的例子用到數(shù)值由空格間隔的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 讀寫數(shù)據(jù)




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':
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


UIGETFILE/UIPUTFILE是基于圖形用戶界面GUI)的。會(huì)彈出對(duì)話框,列出當(dāng)前目錄的文件和目錄,提示你選擇一個(gè)文件。UIGETFILE讓你選擇一個(gè)文件來(lái)寫(類似Windows ‘另存為’選項(xiàng)?)。用UIGETFILE,可以選擇已存在的文件改寫,也可以輸入新的文件名。兩個(gè)函數(shù)的返回值是所選文件名和路徑。


Example:
用 UIGETFILE 從當(dāng)前目錄選擇一個(gè) 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 一次只能選擇一個(gè)文件。


UIIMPORT/IMPORTDATA


UIIMPORT是一個(gè)功能強(qiáng)大,易于使用的基于GUI的high level routine,用于讀complex data files。文件也必須是homogeneous。


IMPORTDATA形成UIIMPORT的功能,不打開(kāi)GUI。可以將IMPORTDATA用于函數(shù)或者腳本中,因?yàn)樵诤瘮?shù)或者腳本中基于GUI的文件導(dǎo)入機(jī)制并不理想。下面的例子用到包含幾行文件頭和文本、數(shù)值數(shù)據(jù)的文件'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')




可以通過(guò)訪問(wèn)結(jié)構(gòu)D的數(shù)據(jù)和文本域,來(lái)看結(jié)構(gòu)D中的真實(shí)值,例如輸入:


data = D.data


text = D.textdata


可以用UIIMPORT讀同一個(gè)文件并得到同樣的結(jié)構(gòu).


注意: 對(duì)于 ASCII data, 你必須檢驗(yàn)導(dǎo)入向?qū)д_的識(shí)別了列分隔符。


TEXTREAD/STRREAD


TEXTREAD 是一個(gè)強(qiáng)大的動(dòng)態(tài)high level routine,設(shè)計(jì)用來(lái)讀ASCII格式的文本和/或數(shù)值數(shù)據(jù)文件。STRREAD除是從字符串而不是文件讀以外,類似于TEXTREAD


兩個(gè)函數(shù)可以用許多參數(shù)來(lái)改變其具體的工作方式,他們返回讀入指定輸出的數(shù)據(jù)。他們有效的提供給你一個(gè)
“兩全其美”的方法,因?yàn)樗麄兛梢杂靡粋€(gè)命令讀入混合的ASCII和數(shù)值數(shù)據(jù)(high level routines的做法),并且你可以改變他們以匹配你特定的應(yīng)用(如同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/CSVREAD


DLMREADDLMWRITE函數(shù)能夠讀寫分隔的ASCII data,而不是用low level routines。他們比low level routines容易使用,Low level routines用幾行代碼實(shí)現(xiàn)的功能可以用DLMREAD/DLMWRITE簡(jiǎn)化成一行。


CSVREAD用來(lái)讀分隔符是逗號(hào)的文件,是DLMREAD的特殊情況。當(dāng)讀空格和Tab分隔的電子數(shù)據(jù)表文件時(shí),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指定范圍的指標(biāo)從0開(kāi)始,而不是從1開(kāi)始。


WK1READ/WK1WRITE


WK1READ 用來(lái)讀Lotus123 電子數(shù)據(jù)表文件的數(shù)據(jù);WK1WRITE用來(lái)寫矩陣到Lotus123 電子數(shù)據(jù)表文件。


XLSREAD


XLSREAD用來(lái)讀Excel的數(shù)值和文本數(shù)據(jù)。


---------------------------------------------------------------------------------------------------------

三. 具體例子分析:
Matlab網(wǎng)站用兩個(gè)例子非常詳盡地介紹了各個(gè)命令的基本用法,實(shí)際中,面對(duì)手頭上的數(shù)據(jù),如何選用合適的命令呢?以下結(jié)合幾個(gè)示例給出一些總結(jié),大家舉一反三就可以了:

1. 純數(shù)據(jù)(列數(shù)相同):
源文件:



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




解答:對(duì)于這個(gè)txt文件,由于各行列數(shù)相同,故簡(jiǎn)單地使用load,importdata均可。


2.字段名(中、英文字段均可)+數(shù)據(jù):
源文件:


CODE:
CH0 CH1 CH2 CH3
0.000123 0.000325 0.000378 0.000598
0.000986 0.000256 0.000245 0.000698


解答:由于是記錄的形式,因此各行列數(shù)必相同(缺少部分列時(shí)請(qǐng)自行在文件中補(bǔ)上 Inf 或 NaN),故直接使用 importdata 便可。

3.注釋(含有獨(dú)立的數(shù)字串)+數(shù)據(jù)(列數(shù)相同):
問(wèn)題:這個(gè)文件有4列,但前6行是文字說(shuō)明,4列數(shù)字是從第8行開(kāi)始的.現(xiàn)在我想把這個(gè)文件的前2列和文字說(shuō)明提出來(lái)組成一個(gè)新的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


目標(biāo)文件:


CODE:
Group 2 12.02.2006 Limei
Samples of datas: 50000

CH0 CH1
0.000123 0.000325
0.000986 0.000256


解答:由于注釋中含有獨(dú)立的數(shù)字串,且注釋部分沒(méi)有明顯的格式,這時(shí)候用importdata, load等高級(jí)命令直接讀取會(huì)失敗,用 textread, dlmwrite 等格式化命令也不太合適,因此只能使用低級(jí)命令進(jìn)行讀取。(當(dāng)然了,可以跳過(guò)注釋部分直接用高級(jí)命令讀取數(shù)據(jù),即:[a b c d] = textread(filename,'%f %f %f %f','headerlines',4); )。一個(gè)簡(jiǎn)單的、非通用的包含注釋的讀取方法如下:
-------------------------------------轉(zhuǎn) ---------------------------------------------------------------------------------------

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  %數(shù)值開(kāi)始
            a=strread(tline);
            a(3:4)=[];
            fprintf(fid_n,'%f %f\n',a);
            clear a;
        elseif double(tline(1))==67   %字母C開(kāi)始
           [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);


---------------------------------------------------------------------------------

4. 注釋(不含獨(dú)立的數(shù)字串)+數(shù)據(jù)(列數(shù)相同):
源文件:

CODE:
你好 abc
歡迎來(lái)到 我們
振動(dòng)論壇
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 便可

注:有時(shí)候注釋中含有獨(dú)立的數(shù)字串也可以 importdata 成功,不過(guò)得到的結(jié)果有可能不正確,建議這時(shí)候使用第3種情形的讀取方式。

5. 注釋與數(shù)據(jù)混排:
對(duì)此當(dāng)然只能自己編程,舉例:

源文件

CODE:
1 11 111 1111
你好
2 22 222 2222
歡迎來(lái)到
3 33 333 3333
振動(dòng)論壇
4 44 444 4444
vib.hit.edu.cn
5 55 555 5555


解答:
--------------------------------------------轉(zhuǎn)--------------------------------------


CODE:

function [data]=distilldata(infile)
%功能說(shuō)明:
%將保存數(shù)據(jù)的原始文件中的數(shù)值數(shù)據(jù)讀入到一個(gè)data變量中
%使用說(shuō)明:
% infile——原始數(shù)據(jù)文件名;
% data=數(shù)據(jù)變量

tmpfile='tmp2.mat';

fidin=fopen(infile,'r'); % 打開(kāi)原始數(shù)據(jù)文件(.list)

fidtmp=fopen(tmpfile,'w'); % 創(chuàng)建保存數(shù)據(jù)文件(不含說(shuō)明文字)

while ~feof(fidin) % 判斷是否為文件末尾
  tline=fgetl(fidin); % 從文件讀入一行文本(不含回車鍵)
  if ~isempty(tline) % 判斷是否空行
    [m,n]=size(tline);
    flag=1;
    for i=1:n %判斷一行中有沒(méi)有字符(+-.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 % 如果是數(shù)字行,把此行數(shù)據(jù)寫入文件
      fprintf(fidtmp,'%s\n',tline);
    end
  end
end

fclose(fidin);

fclose(fidtmp);

data=textread(tmpfile);

delete(tmpfile);



---------------------------------------------------------------------------------------------------------
另外,如果要求不高,也可以使用 textread 函數(shù)跳過(guò)注釋部分進(jìn)行讀取,不過(guò)前提是需要事先知道文件內(nèi)容的結(jié)構(gòu)(即哪行是數(shù)據(jù)、哪行是注釋)

6.各列數(shù)據(jù)的分離:
源文件:


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'); 便可


四. 注意事項(xiàng):

1. 請(qǐng)?jiān)?matlab 中保持當(dāng)前路徑在該數(shù)據(jù)文件對(duì)應(yīng)的目錄下進(jìn)行存取,否則,存取時(shí)請(qǐng)給出該數(shù)據(jù)文件的具體路徑。


2. 存取時(shí),請(qǐng)給出該數(shù)據(jù)文件的全稱(包括后綴名,讀取mat文件時(shí)可省略)


3. load data.txt和A=load(‘data.txt’)的區(qū)別請(qǐng)參閱精華貼:[原創(chuàng)]寫給學(xué)習(xí) matlab 的新手們


4. 請(qǐng)根據(jù)讀寫需要來(lái)打開(kāi)文件,即根據(jù)你的需要來(lái)指定 fopen 的 permission 屬性為讀或?qū)?。如果只?a 進(jìn)行寫入,就不能用 fread 讀取。此時(shí)應(yīng)該寫完關(guān)閉文件,然后用 r 打開(kāi)讀取,或者直接用 a+ 進(jìn)行同時(shí)讀寫操作。否則,會(huì)產(chǎn)生莫名其妙的問(wèn)題!以下代碼是一個(gè)錯(cuò)誤的例子:



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中的數(shù)據(jù)全部讀出,即s矩陣。
fclose(fid);




此時(shí)得到的dd, ll 是錯(cuò)誤且無(wú)意義的!


五. 其他相關(guān)問(wèn)題:

1. 連續(xù)讀取多個(gè)文件的數(shù)據(jù),并存放在一個(gè)矩陣中:
(1) 首先是如何讀取文件名:
方法一:
filename=dir(‘*.jpg’);
那么第i個(gè)文件的文件名就可以表示為
filename(i).name
文件數(shù)量為:length(filename)

方法二:
先在Windows的 MSDOS(命令行)中使用以下命令生成一個(gè)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細(xì)胞矩陣中,最后對(duì)filename{i}便可得到各文件名。


(2) 然后是讀取文件名的數(shù)據(jù)并存儲(chǔ):
假設(shè)每個(gè)文件對(duì)應(yīng)的數(shù)據(jù)是m*n的,則:

CODE:
k = length(filename);

Data = zeros(m,n,k);

for ii = 1:k
  Data(:,:,ii) = yourreadstyle(filename{ii}); %yourreadstyle是對(duì)應(yīng)的文件讀取方式的函數(shù)
end




2. 連續(xù)讀取多個(gè)文件的數(shù)據(jù),并存放在多個(gè)矩陣(以文件名命名)中:
假設(shè)每個(gè)文件對(duì)應(yīng)的數(shù)據(jù)是m*n的,則以上述第二種文件名讀取方法為例:

CODE:
k = length(filename);
for ii = 1:k
  D = yourreadstyle(filename{ii});
eval([‘Data_’, num2str(ii), ‘ = D;’]);
end



3. 文件名命名問(wèn)題:
文件名為 abc00001,abc00002,... abc00009,abc00010,... abc00099,abc00100,...abc00879.  準(zhǔn)備把這些文件名給放到一個(gè)數(shù)組里面去。

解答:

CODE:
a=cell(879,1);
for k=1:879
     a{k} = sprintf('%.5d',k);
end


4. 上述各種文件格式、類型自動(dòng)識(shí)別問(wèn)題:可以利用正則表達(dá)式來(lái)處理,使之通用性較強(qiáng)。例如使用以下代碼可以自動(dòng)處理上面提到了例1到例5各種情形,不過(guò)由于存在自動(dòng)判斷,對(duì)某些例子(如例1)效率自然要低一點(diǎn),而對(duì)于另外的例子(如例3、例5)效率估計(jì)要高一點(diǎn)(少用了一個(gè)循環(huán))。


CODE:

function [data]=distilldata_eight(infile)
%功能說(shuō)明:
%將保存數(shù)據(jù)的原始文件中的數(shù)值數(shù)據(jù)讀入到一個(gè)data變量中(自動(dòng)判斷數(shù)據(jù)行)
%使用說(shuō)明:
% infile——原始數(shù)據(jù)文件名;
% data=數(shù)據(jù)變量

tmpfile='tmp2.mat';

fidin=fopen(infile,'r'); % 打開(kāi)原始數(shù)據(jù)文件(.list)

fidtmp=fopen(tmpfile,'w'); % 創(chuàng)建保存數(shù)據(jù)文件(不含說(shuō)明文字)

while ~feof(fidin) % 判斷是否為文件末尾
  tline=fgetl(fidin); % 從文件讀入一行文本(不含回車鍵)
  if ~isempty(tline) % 判斷是否空行
    str = '[^0-9 | \. | \- | \s | e | E]'; %正則表達(dá)式為:該行中是否包含除 - . E e 數(shù)字 和 空白字符 外的其他字符
    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)



5. 大量數(shù)據(jù)的讀取問(wèn)題:
可以考慮使用循環(huán)分批讀取(特別是在各數(shù)據(jù)是獨(dú)立的時(shí)候),或者使用稀疏矩陣來(lái)實(shí)現(xiàn)(對(duì)此可以參閱本版精華貼: [原創(chuàng)]提高matlab運(yùn)行速度和節(jié)省空間的一點(diǎn)心得(之三))。另外,也可參考《深入淺出MATLAB 7_X混合編程》一書(shū)第一章

6. 讀取整個(gè)txt文件的內(nèi)容(獲得文件中的所有字符):

CODE:

f = fopen('yourfilename.txt','rt'); % t 屬性根據(jù)需要可省略
x = fread(f,'*char');
fclose(f);


7. 把維數(shù)不同的矩陣及其變量名保存到一個(gè) txt 文件中,例如 a1 = 123; a2 = [1 2 3;4 5 6] ,希望得到的 txt 文件如下:


QUOTE:

a1:
123
a2:
1 2 3
4 5 6





如果寫入的時(shí)候簡(jiǎn)單一點(diǎn),則可以采用以下方式,不過(guò)讀取的時(shí)候比較麻煩:

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);


相反,如果寫入的時(shí)候復(fù)雜一點(diǎn),則讀取的時(shí)候會(huì)簡(jiǎn)單一點(diǎn):

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);

Matlab中文論壇:   www.iLoveMatlab.cn

本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開(kāi)APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
Matlab 文件讀寫函數(shù)
matlab中如何讀取TXT數(shù)據(jù)文件【轉(zhuǎn)載】
數(shù)據(jù)文件處理
Matlab如何連續(xù)將數(shù)據(jù)寫入TXT文件
matlab的各種數(shù)據(jù)讀?。╰xt,dat,mat等格式),文件打開(kāi)關(guān)閉
Matlab實(shí)現(xiàn)文件讀寫的幾種方法
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服