- 在线时间
- 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函数。, S$ w4 U+ b8 D1 B* j
它的基本语法是:( S! V7 t9 L& `& U3 \ v' m
[A,B,C,...] = textread(filename,format)
: R1 S- U" B9 E. O& f+ I[A,B,C,...] = textread(filename,format,N)* M* C: E9 e+ j% R4 L
其中filename就是文件名, format就是要读取的格式,A,B,C就是从文件中读取到的数据。
3 q8 f8 U. l$ j1 J# X. I" V6 \中括号里面变量的个数必须和format中定义的个数相同。 如果每N行相同格式的数据,可采用[A,B,C,...] = textread(filename,format,N)的语法,读取N次。
6 J* G h K) E ] `举例如下:
' k8 C9 O3 |, x# M$ _例子1:myfile.txt 中的内容如下:
4 j% b7 y) B) q3 A1 2 3 4+ t! \( B9 E. n# u9 l1 O# ^" H, n
5 6 7 88 ]/ m* |+ ]: p/ h+ U4 d
9 10 11 12* |; ]! s+ l# Z
相应的语句为:
* B& r; J. N/ P' d1 F9 S) }filename = '.\myfile.txt';+ {3 |+ z7 O; t
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n');$ O! B/ v X# o/ i% M
或者为8 L9 M# a* @ b& H5 T5 `& k
filename = '.\myfile.txt';5 [6 k e' i# L! p' F! J
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n',3);+ m( r4 f( x2 O& o1 A$ X
* S+ E8 @, Q+ f! Z. j2 r& j
例子2:myfile.txt 中的内容如下:- x/ S* ^$ ]" v! q1 l9 l; L
1, 2, 3, 4
) U: B0 f' Q# m5 P5, 6, 7, 8
" T8 J! E$ z$ }% ^9 m i* Z9, 10, 11, 12: ?/ x6 Z' [. v8 T
相应的语句为:
( Q0 C y& l& s; jfilename = '.\myfile.txt';
) O. H( T7 i4 M* }5 r8 F[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',');( B' g; m) W- G7 T3 E$ D1 z% f
这里delimiter指出分隔符,读数据的时候会自动跳过分隔符。& p9 @( z6 `" W4 |2 M7 ^
% P5 V" F" P8 E* T0 u3 M# F( J
; r, E2 J6 R# |
例子3:myfile.txt 中的内容如下:
* q8 }$ S; w S6 q% this a comment1 W q3 e7 y, ^( L3 i6 Z3 x
1, 2, 3, 4
- U- `9 K+ k) b% m" N5, 6, 7, 8
; U. V( Z% k+ E! H* K, G6 x0 _, P9, 10, 11, 124 J4 X5 M4 c+ K; T! A v8 Y. D
相应的语句为:
$ Q. R2 b8 y" Q& w" u' T& Gfilename = '.\myfile.txt';* Z5 v: w- @2 r$ }/ F, ~' q3 L
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',','headerlines', 1);
, D3 T0 G j% K! l- O2 B' N: ?3 V这里告诉textread跳过一开始的1行,1可以替换为任意你要跳过的行数。
8 n* X9 U: l r; B9 s
1 z! m. S5 G+ N# m) Y g5 J- {例子4:myfile.txt 中的内容如下:
9 [7 _2 \5 F9 L qSally Level1 12.34 45 Yes
3 e8 M* G6 {; ~% m相应语句为:4 C) I' V- ?& o1 w1 \
' u$ J; E( A ^7 q
filename = '.\myfile.txt';1 Y/ J1 G0 s; W& x' t% O
" b) k$ N, x" ]8 o) R$ R
[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)4 t n. [" J# i* P. k: x
%*f 告诉textread跳过一个浮点数。# _( a X: l ?5 R
4.2 如果要忽略Level,指读取后面的数字,
4 R( g/ L# ?8 f3 o& V( P
& r) [ v$ K6 @+ l[names, levelnum, x, y, answer] = textread(filename , ... '%s Level%d %f %d %s', 1)例子5:myfile.txt 中的内容如下$ @7 k8 [/ |; x& v- b7 q! g# Z
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' ,';');注意:
! ?4 ^! O# ?, b6 Stextread不用先fopen那个文件,适用于格式统一的txt文件的一次性大批量读取。textread读取某个文件后,下次再用textread读取这个文件时,还是会从文件头开始读取。 |
zan
|