- 在线时间
- 20 小时
- 最后登录
- 2012-10-25
- 注册时间
- 2012-7-18
- 听众数
- 6
- 收听数
- 0
- 能力
- 0 分
- 体力
- 476 点
- 威望
- 0 点
- 阅读权限
- 30
- 积分
- 173
- 相册
- 0
- 日志
- 4
- 记录
- 1
- 帖子
- 57
- 主题
- 4
- 精华
- 0
- 分享
- 1
- 好友
- 10
升级   36.5% TA的每日心情 | 怒 2012-10-25 23:22 |
---|
签到天数: 49 天 [LV.5]常住居民I
 群组: Matlab讨论组 群组: 学术交流B |
实际应用中经常要读取txt文件,这个时候就需要用到强大的textread函数。! s: C/ O" A' Q& R' V. s. _
它的基本语法是:
6 o1 T! E# b! w& N: X2 P" Z[A,B,C,...] = textread(filename,format)
8 }# a3 h t) W: Q# S& {# s[A,B,C,...] = textread(filename,format,N)
0 _" U* r% H0 H) g* O" B其中filename就是文件名, format就是要读取的格式,A,B,C就是从文件中读取到的数据。
$ V' G+ `- d& d( `& a9 ^, d中括号里面变量的个数必须和format中定义的个数相同。 如果每N行相同格式的数据,可采用[A,B,C,...] = textread(filename,format,N)的语法,读取N次。 F9 _. k6 |8 a0 W2 H* Z( G
举例如下:
+ [1 ^+ ~& o& [0 k: n例子1:myfile.txt 中的内容如下:% O, ^2 ~- j4 Y. c. B& I
1 2 3 4
$ O0 q6 z6 e% _% I* a c" R5 6 7 8* b6 i: @* E+ Y! m3 Q& ^
9 10 11 12
; a/ D3 d: a+ J: F# Q& A相应的语句为:
" T7 x( ?: p' f6 lfilename = '.\myfile.txt';; m" R: c$ T3 k. ^
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n');
% l+ L1 ~/ p. ^. I# G; M4 ?( \或者为) f. A0 M4 P! F1 P$ i0 V
filename = '.\myfile.txt';" n; a( @# a6 s0 w1 f) M8 y
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n',3);
; u7 H9 R0 D1 G$ s7 p" J5 ?. z* W3 X
例子2:myfile.txt 中的内容如下:7 ^5 L3 `$ L) T& ~6 {
1, 2, 3, 4
2 L: F* U0 T( E6 W5, 6, 7, 8% A" i/ M8 h& r$ ?
9, 10, 11, 12* g) c* J( M( f1 [# H8 ]+ q9 z* f
相应的语句为:/ E$ y/ k: e) j, I+ q+ v
filename = '.\myfile.txt'; P2 q4 M. G2 \* ^% p: }6 \3 t& C* w
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',');2 ]) @6 R4 Q$ I3 j4 w2 ?% m
这里delimiter指出分隔符,读数据的时候会自动跳过分隔符。
5 I* Q% p. @! h- ^# A7 K- t3 h. Y+ ^5 H: @, N m5 o, X
7 p( D' c+ A' `/ D& V例子3:myfile.txt 中的内容如下:
2 q$ Z5 G( i1 }( \5 W- `% this a comment0 n5 r( e7 }. v" |: O! i; _
1, 2, 3, 4
; G8 [ |: O) O% E3 ?5, 6, 7, 8: q2 j: M, A1 Y3 A. y+ T
9, 10, 11, 12
) t) U' b# V2 Q( ]( m相应的语句为:1 U- U6 _% n+ e5 C4 E9 r
filename = '.\myfile.txt';
7 b1 M7 G* R& Z, r" `. Y2 B[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',','headerlines', 1);( b& P/ ? p5 z. z* x# h5 N0 f' d; {! K
这里告诉textread跳过一开始的1行,1可以替换为任意你要跳过的行数。
4 P% W0 Z% z% |# S1 t
4 L9 e+ b( A4 p$ V1 j# ^# {例子4:myfile.txt 中的内容如下:
6 Z2 w0 F6 V$ x' G/ T9 B* D5 MSally Level1 12.34 45 Yes+ e: q* v8 X; Z+ j+ j8 U
相应语句为:4 M7 Z: M0 }* O, O( {
5 [6 g1 `2 f; Y8 H0 yfilename = '.\myfile.txt';1 c& f w+ p; M# q& X% c. m
, m; F8 N8 G$ R/ @* x! O/ R
[names, types, x, y, answer] = textread(filename , '%s %s %f %d %s', 1)4.1如果要忽略12.34这个浮点数。[names, types, y, answer] = textread(filename , '%s %s %*f %d %s', 1)
1 m% @- J" y# O `%*f 告诉textread跳过一个浮点数。
, y0 G8 f; W& T- g5 O! B3 L4.2 如果要忽略Level,指读取后面的数字,
- a: w6 e7 T* Y$ a3 R# {3 c% l9 |( c: |: p0 }
[names, levelnum, x, y, answer] = textread(filename , ... '%s Level%d %f %d %s', 1)例子5:myfile.txt 中的内容如下
) q% o; I6 a$ S+ q& d$ J1,2,3,4,,6 7,8,9,,11,12想用nan替代为空的部分。语句如下:data = textread('myfile.txt', 'delimiter', ',', 'emptyvalue', NaN);例子6: myfile.txt 中的内容如下 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 中的内容如下 Location;date;discharge Lobith;1989-01-01;00:00;2801Lobith;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' ,';');注意:4 y, K# @3 w0 T3 a- h
textread不用先fopen那个文件,适用于格式统一的txt文件的一次性大批量读取。textread读取某个文件后,下次再用textread读取这个文件时,还是会从文件头开始读取。 |
zan
|