- 在线时间
- 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函数。% z6 a8 y4 G. z& z5 c- n
它的基本语法是:
& \) {; T* v, E) ~[A,B,C,...] = textread(filename,format)
( ^; M% U. [; D+ V/ R9 T ^[A,B,C,...] = textread(filename,format,N)
, U* z M8 Y& o3 L) U+ z其中filename就是文件名, format就是要读取的格式,A,B,C就是从文件中读取到的数据。' z9 g5 T3 h6 C
中括号里面变量的个数必须和format中定义的个数相同。 如果每N行相同格式的数据,可采用[A,B,C,...] = textread(filename,format,N)的语法,读取N次。
8 q! E6 v. e: T% g举例如下:& |/ i3 Y- C! M8 t
例子1:myfile.txt 中的内容如下:
2 |* Z5 e. |& e# y. }' y' |1 P1 2 3 4- V+ D& y+ r! }7 @
5 6 7 8
% m& N* S, a) r7 F5 ^9 10 11 12
! m! ~* m! e. M相应的语句为:
4 h6 J# v* ^6 A7 T3 \. n! p9 Q# ifilename = '.\myfile.txt';' H% _4 P' U1 ?
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n');7 T9 D; ^% W1 a
或者为9 D0 i! C; k3 W" h, \8 M
filename = '.\myfile.txt';
( d8 v0 X# {1 l8 W[data1,data2,data3,data4]=textread(filename,'%n%n%n%n',3);* ?8 N4 i; d7 ?
) u1 f1 C: t6 m5 M例子2:myfile.txt 中的内容如下:( K+ P C7 X4 j1 N8 i
1, 2, 3, 4
+ L9 R6 v) Z) b+ O( s9 s( ~3 }5, 6, 7, 8' K* k# Y) {# ~1 O
9, 10, 11, 12
9 T* Y' ]8 b/ r9 J) l! h4 E1 j相应的语句为:& Z& {0 ?7 U$ _4 y3 Y$ |4 m. |' Q
filename = '.\myfile.txt';
4 m2 Y# u! n6 e8 X[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',');
! d6 s! X2 g8 |5 Z) Z$ t2 i这里delimiter指出分隔符,读数据的时候会自动跳过分隔符。
6 y- r) s% L% R# g( I& x0 }& C% y& m
3 G! _, I2 r3 `1 I- X1 V$ ?例子3:myfile.txt 中的内容如下:: N& Y7 H4 ^: O0 _9 L" Y
% this a comment
8 \! a" t5 X3 s' ^% g1 I% X @& z1, 2, 3, 4
( _ S0 C7 q8 W+ N5, 6, 7, 8
6 S- j+ I$ z3 ^/ }9, 10, 11, 12
* m7 q, F" v) Q; }: U7 {相应的语句为:
5 S' Z8 {' E' |5 a$ M7 d8 Ffilename = '.\myfile.txt';
( p" Q- c+ @# L( M) X% e[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',','headerlines', 1);9 R( @: n# y* y8 F
这里告诉textread跳过一开始的1行,1可以替换为任意你要跳过的行数。/ d& Y6 T! T8 V: [; S5 s
. f* r1 `: p+ }# t$ c3 G, R& d例子4:myfile.txt 中的内容如下:" G- u, p* k9 R" G
Sally Level1 12.34 45 Yes0 q) S9 h2 U: T# U9 d+ u1 k
相应语句为:; p7 A% z- {' j: v a: t! H2 w
& i. m4 J) h& N3 Z9 A X7 j% N) B
filename = '.\myfile.txt';6 ]4 H, {2 j- }7 [& m& v, a
5 _' \, X. t$ R/ U8 {3 F# L
[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)
8 H- D$ [6 [1 _7 S3 J7 Z%*f 告诉textread跳过一个浮点数。
E8 ^! {3 j0 O8 F( ]8 X4 h" C. D4.2 如果要忽略Level,指读取后面的数字,
3 O3 L- X {+ I4 o- i! T& M9 M
3 I- D2 B( c0 {4 @1 Q# d2 C; ~' T[names, levelnum, x, y, answer] = textread(filename , ... '%s Level%d %f %d %s', 1)例子5:myfile.txt 中的内容如下
% H6 Y0 S5 j% h* M6 G2 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' ,';');注意:
6 r# ]+ L% S3 v; |0 Q' ]6 Ttextread不用先fopen那个文件,适用于格式统一的txt文件的一次性大批量读取。textread读取某个文件后,下次再用textread读取这个文件时,还是会从文件头开始读取。 |
zan
|