昨天學(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)%這個(gè)函數(shù)用來實(shí)現(xiàn)把a(bǔ)到b平均分成c個(gè)數(shù)。
例如:
a=linspace(1,30,8);
save D:exper.txt a-ascii;? ?%這一行代碼實(shí)現(xiàn)把a(bǔ)以ascii碼存在D盤的exper目錄下面,如果不存在楚堤,? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? %將自動(dòng)創(chuàng)建該文件,如下圖所示在D盤創(chuàng)建了一個(gè)exper.txt文件含懊。
b=load('D:\exper.txt')? ?%這個(gè)語句實(shí)現(xiàn)把D盤下面的exper文本文檔讀到matlab下身冬。
(2)讀文件中含有不同數(shù)據(jù)類型的文件。
上面(1)中讀取的txt文件是以ascii碼存儲(chǔ)的岔乔,有些文件中的數(shù)據(jù)包含不同的數(shù)據(jù)類型酥筝,比如有字符型,整形雏门,浮點(diǎn)型等嘿歌。如果文件中存儲(chǔ)了不同類型的字符和數(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ù):