昨天學(xué)習(xí)內(nèi)容如下:主要學(xué)習(xí)matlab與txt文本進(jìn)行交互的一些操作,有從matlab讀入txt文件的函數(shù)load()的使用,還有從matlab寫入txt文件的函數(shù)fprintf()函數(shù)。
(1)讀入txt文件內(nèi)容。
linspace(a,b,c)%這個函數(shù)用來實現(xiàn)把a(bǔ)到b平均分成c個數(shù)。
例如:
a=linspace(1,30,8);
save D:exper.txt a-ascii;? ?%這一行代碼實現(xiàn)把a(bǔ)以ascii碼存在D盤的exper目錄下面,如果不存在,? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? %將自動創(chuàng)建該文件,如下圖所示在D盤創(chuàng)建了一個exper.txt文件。
b=load('D:\exper.txt')? ?%這個語句實現(xiàn)把D盤下面的exper文本文檔讀到matlab下。


(2)讀文件中含有不同數(shù)據(jù)類型的文件。
上面(1)中讀取的txt文件是以ascii碼存儲的,有些文件中的數(shù)據(jù)包含不同的數(shù)據(jù)類型,比如有字符型,整形,浮點型等。如果文件中存儲了不同類型的字符和數(shù)據(jù),分類讀取數(shù)據(jù)需要用到textread函數(shù)。使用該函數(shù)的好處:可以做到控制輸出更精準(zhǔn)以及不需要使用fopen命令打開文件就可以直接讀取txt里面的內(nèi)容。語法:
[A,B,C,....]=textread('filename','format',N,'headerlines',M)
其中,filename表示要讀取的txt文件名稱
format表示讀入變量的字段格式
N表示讀取的次數(shù),每一次讀取一行
headerlines表示從M+1行開始讀入。例如,要讀取的數(shù)據(jù)如下圖txt文本內(nèi)容所示:

在matlab命令窗口寫代碼如下:
[name,type,x,y,answer]=textread('D:\t.txt','%s Type %d %f %n %s',2,'headerlines',1)
%txt文本中不含表頭信息
換行之后即可在matlab下讀取txt文本內(nèi)容,結(jié)果如圖:

(3)matlab讀取m文件的漢子字符信息
函數(shù)fopen可以打開m文件,r表示只讀形式,w表示寫入形式,a表示在文件末尾添加內(nèi)容
例如:在matlab中寫代碼如下:

(4)寫入TXT文件內(nèi)容
主要用到fprintf函數(shù)

在相應(yīng)的目錄文件下可以看到通過matlab寫入了以下數(shù)據(jù):
