Matlab读取txt文件中的数据(使用textread函数)
在使用Matlab處理數(shù)據(jù)時,我們經(jīng)常需要讀取txt文檔,可以使用Matlab中強大的textread函數(shù)。
它的基本語法是:
[A,B,C,...] = textread(filename,format)
[A,B,C,...] = textread(filename,format,N)
其中filename就是文件名, format就是要讀取的格式,A,B,C就是從文件中讀取到的數(shù)據(jù)。
中括號里面變量的個數(shù)必須和format中定義的個數(shù)相同。 如果每N行相同格式的數(shù)據(jù),可采用[A,B,C,...] = textread(filename,format,N)的語法,讀取N次。
?
舉例如下:
例1:myfile.txt 中的內(nèi)容如下:
? ? 1 2 3 4
? ? 5 6 7 8
? ? 9 10 11 12
相應的語句為:
filename = '.\myfile.txt';
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n');
或者為
filename = '.\myfile.txt';
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n',3);
例2:myfile.txt 中的內(nèi)容如下:
? ? 1, 2, 3, 4
? ? 5, 6, 7, 8
? ? 9, 10, 11, 12
相應的語句為:
filename = '.\myfile.txt';
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter',?',');
這里delimiter指出分隔符,讀數(shù)據(jù)的時候會自動跳過分隔符。
例3:myfile.txt 中的內(nèi)容如下:
? ? % this a comment
? ? 1, 2, 3, 4
? ? 5, 6, 7, 8
? ? 9, 10, 11, 12
相應的語句為:
filename = '.\myfile.txt';
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter',?',','headerlines',?1);
這里告訴textread跳過一開始的1行,1可以替換為任意你要跳過的行數(shù)。
例4:myfile.txt 中的內(nèi)容如下:
相應語句為:
filename = '.\myfile.txt';
[names, types, x, y, answer] = textread(filename?, '%s %s %f %d %s', 1)?
? ? ①如果要忽略12.34這個浮點數(shù):[names, types, y, answer] = textread(filename?, '%s %s %*f %d %s', 1)。?%*f告訴textread跳過一個浮點數(shù)。
? ? ②如果要忽略Level,只讀取后面的數(shù)字:[names, levelnum, x, y, answer] = textread(filename?, ... '%s Level%d %f %d %s', 1)?
?
例5:myfile.txt 中的內(nèi)容如下
? ? 1,2,3,4,,6
? ? 7,8,9,,11,12?
? ? 想用nan替代為空的部分。語句如下:data = textread('myfile.txt', 'delimiter', ',', 'emptyvalue', NaN)。
?
例6:?myfile.txt 中的內(nèi)容如下
? ? Sally????Type1 12.34 45 Yes?
? ? Joe??????Type2 23.54 60 No?
? ? Bill?????Type1 34.90 12 No?
? ? 如果只想讀第一列,其余的跳過:
? ? filename = '.\myfile.txt';?
? ? [names]=textread(filename,'%s%*[^\n]')?
? ? %[^...] - reads characters not matching characters between the brackets until first matching character
? ? %[^\n] 就是一直讀到行尾
? ? %*[^\n] 就是從當前直接跳到行尾
? ? 可對比:[names,rest]=textread(filename,'%s%[^\n]')??
例7:?myfile.txt 中的內(nèi)容如下???????????????????
? ? Location;date;discharge??
? ? Lobith;1989-01-01;00:00;2801?
? ? Lobith;1989-01-02;00:00;2619?
? ? 語法如下:?
? ? [Location,... % 1????
? ? yyyy??????????????,... % 2a datestring year????
? ? mm????????????????,... % 2b datestring month????
? ? dd????????????????,... % 2c datestring day????
? ? HH????????????????,... % 3a timestring hour????
? ? MM????????????????,... % 3b timestring minute????
? ? discharge] =??...????
? ? textread(filename,'%s%f-%f-%f%f:%f%f',...????????
? ? ? ? 'headerlines',1,...????????
? ? ? ? 'delimiter'??,';');?
注意:textread不用先fopen那個文件,適用于格式統(tǒng)一的txt文件的一次性大批量讀取。textread讀取某個文件后,下次再用textread讀取這個文件時,還是會從文件頭開始讀取。
總結
以上是生活随笔為你收集整理的Matlab读取txt文件中的数据(使用textread函数)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: B样条数据点反求控制点绘制曲线(源码)
- 下一篇: MATLAB中多个一维数组的合并