- 在线时间
- 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函数。! Q- r; f7 R( E# t
它的基本语法是:2 ?; t; T+ e/ U( r/ J5 F0 X
[A,B,C,...] = textread(filename,format)
8 ^; h+ J6 p; W" t5 t$ o[A,B,C,...] = textread(filename,format,N)" u3 q5 ?# {/ |) s
其中filename就是文件名, format就是要读取的格式,A,B,C就是从文件中读取到的数据。2 U" ?+ }9 S+ H# v1 K3 n$ Q5 v
中括号里面变量的个数必须和format中定义的个数相同。 如果每N行相同格式的数据,可采用[A,B,C,...] = textread(filename,format,N)的语法,读取N次。
, m& e# ?. [7 n, M0 {举例如下:7 c% z4 T% q0 @4 j7 E& ?* M
例子1:myfile.txt 中的内容如下:
w6 j% Y7 v! K1 D1 2 3 4) S) l" @* F& V+ t5 B8 v& _* B
5 6 7 82 V0 I9 ]" l9 l1 [
9 10 11 12/ Z2 h- T- q9 M7 C
相应的语句为:3 E: G" ?* J( @& b) P
filename = '.\myfile.txt';
: j, Q- Z. I3 w, [* D* C[data1,data2,data3,data4]=textread(filename,'%n%n%n%n');' s9 q$ ]& P: E0 N8 E5 E; u6 I
或者为
$ Q2 }9 v/ L: l$ Yfilename = '.\myfile.txt';2 O3 A; e" C( U5 L* L, Y- y$ z
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n',3);( B: \& L6 x# j1 i% R4 l, d
. x4 ]7 T$ T% `% p例子2:myfile.txt 中的内容如下:: q: ?. \ r5 d
1, 2, 3, 4# a4 r0 C7 V* J6 T
5, 6, 7, 8
* L0 w: f# i" b9, 10, 11, 12
( X0 A8 R5 U8 E- z4 G4 p( Q' z相应的语句为:
2 U' d" ?( h, o" O" rfilename = '.\myfile.txt';
' ^+ @6 H8 V& A+ R* K( ?[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',');+ m/ ?2 _2 Y" W2 a- B* Q9 I& W
这里delimiter指出分隔符,读数据的时候会自动跳过分隔符。) b" p7 X& [7 F; z. P2 I
2 T2 \$ D. l8 i( i1 P5 ^/ Y3 F# E) ^" M: [% D4 r7 H/ g: m
例子3:myfile.txt 中的内容如下:
+ e5 j [+ T1 ]0 }* n% this a comment
* `' A8 E6 T4 g; {/ ]" L1, 2, 3, 46 `* w0 N6 [; b
5, 6, 7, 8
y/ Q/ L" Y. E. ^' ?4 T' m9, 10, 11, 12
3 n9 S6 G: W$ d相应的语句为:
7 A B- l1 A0 K# Hfilename = '.\myfile.txt';/ `9 j4 d' t- q/ |$ D# A
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',','headerlines', 1);' X; U: e6 E9 l/ @. W/ |) U
这里告诉textread跳过一开始的1行,1可以替换为任意你要跳过的行数。
0 P( v8 w. p8 A% J) _% j8 Q, u1 D' p$ ? p! ~& S
例子4:myfile.txt 中的内容如下:6 n9 Q# p' K1 s
Sally Level1 12.34 45 Yes0 M: W( ^# G' q, B+ F
相应语句为:
, O/ `7 J+ r/ a1 ], N+ t' G9 n, Y# D# c F" Z# Q" C! i
filename = '.\myfile.txt'; H4 Q4 k( `2 o2 K5 C0 L# u* p
9 h4 R* H* i8 ^7 y[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)" j! T/ o5 M3 r
%*f 告诉textread跳过一个浮点数。1 f& Q% @4 @# m4 F3 u/ d+ ?
4.2 如果要忽略Level,指读取后面的数字,6 F. c& w; U$ h3 T
5 X0 g2 p$ K0 Z' Q% }3 [* v
[names, levelnum, x, y, answer] = textread(filename , ... '%s Level%d %f %d %s', 1)例子5:myfile.txt 中的内容如下
( S& @( s; g+ v6 ?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' ,';');注意:+ }' u$ E; M7 D; M
textread不用先fopen那个文件,适用于格式统一的txt文件的一次性大批量读取。textread读取某个文件后,下次再用textread读取这个文件时,还是会从文件头开始读取。 |
zan
|