- 在线时间
- 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函数。' f3 ~* P2 j1 Q3 |
它的基本语法是:/ h1 Z5 [, x# H0 h7 [' I( p
[A,B,C,...] = textread(filename,format), Y |5 v- Q$ t% ~ W
[A,B,C,...] = textread(filename,format,N)
8 |) i g+ A$ s& Y* d i8 y其中filename就是文件名, format就是要读取的格式,A,B,C就是从文件中读取到的数据。
& A9 D, m$ n1 v0 f4 f7 L2 R% k中括号里面变量的个数必须和format中定义的个数相同。 如果每N行相同格式的数据,可采用[A,B,C,...] = textread(filename,format,N)的语法,读取N次。; b2 J. t" @' X8 z4 ^/ Z
举例如下:
- ]5 ?* A* X) F% @3 z例子1:myfile.txt 中的内容如下:' e1 k' s3 p7 q
1 2 3 4
5 P: J$ v; g1 Y) n5 6 7 8. N4 X# W! w- O6 c3 w
9 10 11 12
Q' y5 \8 b" a n$ N: T3 u; u) X/ n相应的语句为:
2 C% ~% U" b$ h4 o7 O% o2 v" |filename = '.\myfile.txt';0 o5 P" o ^. P1 Q$ `# |3 D( _
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n');
0 V/ s/ O: } j, g4 ^. k或者为
9 o6 ^9 v: _, q; S J4 H( Efilename = '.\myfile.txt';
5 _1 h+ X! z$ |* K/ I4 Z2 q2 t, ][data1,data2,data3,data4]=textread(filename,'%n%n%n%n',3);+ M7 R( n0 W1 |+ m0 g! \
0 r9 _& T9 [) c) T: A
例子2:myfile.txt 中的内容如下:! W- K {" g9 y, e) L
1, 2, 3, 4( y1 r( j# F: d) v
5, 6, 7, 8
) S8 m+ |% K- h- M; x6 A- I# y9, 10, 11, 12& i0 D# i" `6 D% @5 G s5 v! A
相应的语句为:
: L( y1 s1 f9 D# A" V vfilename = '.\myfile.txt';
7 o; |' g% Q0 P$ F7 L6 A) ?" s0 b[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',');: U6 G: ]/ H6 Q; s( r4 U1 u( w
这里delimiter指出分隔符,读数据的时候会自动跳过分隔符。% |' t/ {. s- t+ j8 t! Y
( g2 V- _0 p1 E$ i) ~, Y4 `
1 W8 ~ D' i6 t0 s
例子3:myfile.txt 中的内容如下:% a$ `. \7 v, n. n3 `% v! ^9 W/ X
% this a comment5 ^ X: Y! B. `2 I
1, 2, 3, 4
* y3 `4 `7 F2 B/ U! e" a9 W5, 6, 7, 88 g/ w P8 A! V# Y
9, 10, 11, 127 i8 m/ |$ u3 m4 C( m
相应的语句为:2 V2 I% k$ l ] Q9 g- r* g
filename = '.\myfile.txt';
7 }. y) Z% s3 K: J$ L[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',','headerlines', 1);! D6 t: ]0 N" j k
这里告诉textread跳过一开始的1行,1可以替换为任意你要跳过的行数。
. c7 O$ X$ _ V% l4 k# z" c& [ M
例子4:myfile.txt 中的内容如下:
3 h0 L; o$ |3 a7 I6 eSally Level1 12.34 45 Yes
" n: Z$ }: a7 I2 a! L" ^- S8 I3 P& p相应语句为:, W$ b* e' Y" |6 }& t
6 m {/ B( w z! j
filename = '.\myfile.txt';) p; q$ K2 j. K7 H0 b
" P$ ?7 y/ S' G7 L4 D[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)
6 F l" E& |3 w0 D/ \% S* f$ q! `%*f 告诉textread跳过一个浮点数。0 h- I1 a7 W% q6 v" R o" m
4.2 如果要忽略Level,指读取后面的数字,
% T+ H, t8 O* R o8 N2 x: s/ i, s5 \6 l" Z
[names, levelnum, x, y, answer] = textread(filename , ... '%s Level%d %f %d %s', 1)例子5:myfile.txt 中的内容如下: }* ?- I) ~: R6 g0 h( w
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' ,';');注意:
" ?( o9 D, T8 t5 @textread不用先fopen那个文件,适用于格式统一的txt文件的一次性大批量读取。textread读取某个文件后,下次再用textread读取这个文件时,还是会从文件头开始读取。 |
zan
|