- 在线时间
- 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函数。, ]6 H9 v1 Z1 T0 z1 i; p
它的基本语法是:
5 v4 c8 P0 o- p# t' I[A,B,C,...] = textread(filename,format)
% I/ h+ q5 T# `[A,B,C,...] = textread(filename,format,N)
( R: Y3 |; c+ k( A- U其中filename就是文件名, format就是要读取的格式,A,B,C就是从文件中读取到的数据。
( U* o) `' L# d9 V, V中括号里面变量的个数必须和format中定义的个数相同。 如果每N行相同格式的数据,可采用[A,B,C,...] = textread(filename,format,N)的语法,读取N次。
* z: R$ {' m3 ]4 {1 Y/ u/ u5 ?举例如下:
5 D+ h9 m( L& L4 ?例子1:myfile.txt 中的内容如下:- S6 H; H) [' B4 z8 E
1 2 3 4
; H3 D; v8 N2 z" ?. y5 6 7 8
0 K( U, s! }3 w) N! }( v) @! k9 10 11 12! A0 N+ f0 V S& |
相应的语句为:
, G% M% F1 A, R3 }$ @8 O8 R' `filename = '.\myfile.txt';* R8 T! {9 j" X0 S
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n');0 m( }* ~2 E( E6 B0 s
或者为
v. B. k; Q$ ]4 }filename = '.\myfile.txt';+ ]. O2 B2 d! w8 h: Q
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n',3);9 U$ a% c I+ V# b" L
7 V& [2 T; q" ~ ^. o" r4 w* B: ?例子2:myfile.txt 中的内容如下:
3 ^5 @4 M! \5 |; E B' O/ Q1, 2, 3, 4
: w0 h! F, n6 s \) y5, 6, 7, 8
+ t9 e1 v4 g3 R8 w h9, 10, 11, 12 s8 f$ q! M+ p; `
相应的语句为:- x) h8 u- c( \- _: R
filename = '.\myfile.txt';
6 i# S4 _+ U$ I8 A- R- s# B[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',');& [2 s0 r' R) T7 F0 ?* E9 N" V8 [
这里delimiter指出分隔符,读数据的时候会自动跳过分隔符。
# ^5 L3 T( h9 Q$ A7 |
8 m9 l# J6 S2 Z( Y5 }& m5 Q" g
4 c" u3 p9 Y; N- v% Y& |例子3:myfile.txt 中的内容如下:5 f+ f/ }/ G) f' w
% this a comment
9 w2 L7 T: y4 b0 f6 ]5 c. R8 T, Q( C; h5 R1, 2, 3, 4
, S. l' j$ K8 E N2 N# m' L" K5, 6, 7, 8
0 d* ~) Q) h7 J* R' }9, 10, 11, 12
5 f) e3 J& A5 j9 {4 ?9 x相应的语句为:
4 p L7 p3 n5 l3 J* m9 \filename = '.\myfile.txt';
7 r5 ?0 y. {8 b; U6 w9 I4 y[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',','headerlines', 1);
" B }9 w" X6 O3 J: I这里告诉textread跳过一开始的1行,1可以替换为任意你要跳过的行数。' b' e- P# a3 H% |
* g( a& p' Z4 r; S2 D例子4:myfile.txt 中的内容如下:
3 f: R2 @$ V- t( O$ c6 F. jSally Level1 12.34 45 Yes7 V% b3 q3 r5 e& p+ v0 F6 z. E9 g
相应语句为:% u, }/ b8 o' t4 p+ _. M
" m O. Y# n0 X' h2 Bfilename = '.\myfile.txt';
7 s0 h$ {3 s! f4 @. F N+ T: o
5 E3 i: O5 z" U( \* 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). P9 ?5 P4 Z; {2 t& u; ~
%*f 告诉textread跳过一个浮点数。1 g# |) b" V. P! m/ b+ J
4.2 如果要忽略Level,指读取后面的数字,
- f7 @/ O4 {1 H; H5 S: m8 d% C, |; c( ^2 \
[names, levelnum, x, y, answer] = textread(filename , ... '%s Level%d %f %d %s', 1)例子5:myfile.txt 中的内容如下; t1 O: q/ c9 w. Y) O2 B7 g- }6 ] U$ b
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' ,';');注意: ]+ k$ y5 v+ t, e3 [" ]
textread不用先fopen那个文件,适用于格式统一的txt文件的一次性大批量读取。textread读取某个文件后,下次再用textread读取这个文件时,还是会从文件头开始读取。 |
zan
|