- 在线时间
- 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函数。
, d0 d% t- u9 S8 j* |) [它的基本语法是:
: Q2 @ s3 [6 G! A( D( `[A,B,C,...] = textread(filename,format)
0 o- {; W4 ?" e/ X" \. |[A,B,C,...] = textread(filename,format,N)
0 `' J$ _/ K6 y# S. j- Z其中filename就是文件名, format就是要读取的格式,A,B,C就是从文件中读取到的数据。
) L% N' ?% B+ J# E$ l! W$ n中括号里面变量的个数必须和format中定义的个数相同。 如果每N行相同格式的数据,可采用[A,B,C,...] = textread(filename,format,N)的语法,读取N次。
- D% |5 g: Q& A8 D" n/ c. H! ^举例如下:
4 x4 ~" [0 c+ O例子1:myfile.txt 中的内容如下:; i/ j; w- r$ K* J$ W" K/ v/ A7 ?
1 2 3 44 g9 O# i3 `/ M0 c7 r
5 6 7 8
/ \5 @( ]$ I6 J% i c9 10 11 129 E- S9 y S4 q. U. R$ o
相应的语句为:. ?4 m- U! }6 W; ^
filename = '.\myfile.txt';$ [# L( w0 V$ @ D' k- b' I
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n');
1 W4 [4 n& d( A. Z9 H或者为
# X/ E8 z% h( C+ g; U' @filename = '.\myfile.txt';
6 O, Y3 w1 F% v8 ?* p[data1,data2,data3,data4]=textread(filename,'%n%n%n%n',3);( r, a% d7 j6 R9 v& x
% q3 y' U' m0 s3 n2 i$ C. o7 W. L例子2:myfile.txt 中的内容如下:' C, A; j8 e0 i" M" K B- F
1, 2, 3, 41 ^( M) N: T' B5 y l1 c& C2 B
5, 6, 7, 8
1 |& o: S# U9 ^" Y9, 10, 11, 12
- c& b3 n0 ^. A/ I( N; m0 N相应的语句为:
# b) X. C) b0 Tfilename = '.\myfile.txt';
# g: d8 x0 I8 s; S[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',');
^% o/ }, X: K- P8 S这里delimiter指出分隔符,读数据的时候会自动跳过分隔符。6 w$ D" r& g% C3 o) a b
4 @8 @' A3 D) F& J/ c8 U( ]( T) z
7 f; o/ K$ h1 U9 z6 t) ~$ _8 K
例子3:myfile.txt 中的内容如下:
9 @" p) G' G9 J% this a comment6 [( x; t& J3 k: T
1, 2, 3, 4
! c# R- G, D7 h6 L3 q6 C5, 6, 7, 8' c) J% Y4 X; o- k* O
9, 10, 11, 12/ q1 a) I5 _+ y6 X) h8 K
相应的语句为:( W8 ~1 _! Q/ t0 J& _
filename = '.\myfile.txt';# ?/ Z* y0 p- ]' _& W
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',','headerlines', 1);
, l+ {5 D7 a4 p: @$ P( P4 {3 T这里告诉textread跳过一开始的1行,1可以替换为任意你要跳过的行数。9 n0 L3 ?. P; o; X
& h: m( Q2 Q) |& F3 S例子4:myfile.txt 中的内容如下:
; R2 a+ y( v: R) k( @$ tSally Level1 12.34 45 Yes
" @9 p% b7 |1 c! j5 m6 o3 |相应语句为:
, S) U6 T5 P6 b9 I' P- h: E1 v6 W* i
filename = '.\myfile.txt';
0 ?8 t# n* C2 x& \" z S
( L% U9 q( t9 r' Z[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): ]2 n6 k% {; R- w$ i! Z
%*f 告诉textread跳过一个浮点数。
# ?+ C( }4 Y# B! G4.2 如果要忽略Level,指读取后面的数字,! q0 U5 ]! m# p( \, R! i: l
% q( a4 Y8 T$ j, r
[names, levelnum, x, y, answer] = textread(filename , ... '%s Level%d %f %d %s', 1)例子5:myfile.txt 中的内容如下& W* z' h$ e" N- I
1,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' ,';');注意:
6 }9 J2 d$ f/ {1 Itextread不用先fopen那个文件,适用于格式统一的txt文件的一次性大批量读取。textread读取某个文件后,下次再用textread读取这个文件时,还是会从文件头开始读取。 |
zan
|