- 在线时间
- 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函数。
! S7 y$ v/ `. ^它的基本语法是:
1 Z; V. P3 S, B G# q[A,B,C,...] = textread(filename,format)2 T$ w! T1 E4 f, E
[A,B,C,...] = textread(filename,format,N)- ?6 V9 E! ~8 c: i& J$ d8 C$ w
其中filename就是文件名, format就是要读取的格式,A,B,C就是从文件中读取到的数据。- q8 ^+ S5 a& G( c; y
中括号里面变量的个数必须和format中定义的个数相同。 如果每N行相同格式的数据,可采用[A,B,C,...] = textread(filename,format,N)的语法,读取N次。
% d. z% v ]! S# n( v$ `举例如下:
2 ]. _4 t7 @7 f+ i$ r# I/ u( u9 y6 _例子1:myfile.txt 中的内容如下:
$ g |* L" v$ @: V3 O1 2 3 44 M% ]( C7 ]3 a/ U# Z3 N
5 6 7 8
& d& i) ~: y, E" f9 10 11 12, W; ^% F& U' r' x6 O7 v
相应的语句为:
- ]/ f6 y4 Z( }' f* b ?# Xfilename = '.\myfile.txt';
3 x( A, v+ k( x9 O$ U[data1,data2,data3,data4]=textread(filename,'%n%n%n%n');
8 i8 b4 [8 k& U1 m或者为
2 a3 S# d7 M* `% x) Yfilename = '.\myfile.txt';# S- S/ q, m( T/ n v! h
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n',3);
# Q1 J: | Z3 z3 [- C. \7 a @( r* d3 b+ J$ F* n5 n* k$ O
例子2:myfile.txt 中的内容如下:0 T& b" B' ^5 Q# o3 S/ Y: Q
1, 2, 3, 4
3 }0 r. Q4 W5 D+ a/ X; s2 y7 w5, 6, 7, 8
5 f7 j4 S2 t4 j3 \( m4 S) w. S9, 10, 11, 12
) ?3 v4 R% X) P5 U- O8 X相应的语句为:* G! S& \" p. c, J% y
filename = '.\myfile.txt';
1 G0 C) J A8 q; }( E[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',');
) X0 W3 i. \0 \- }% r% [这里delimiter指出分隔符,读数据的时候会自动跳过分隔符。
( Y# w1 S3 u% s3 k% A: y0 N5 H0 m4 R7 c# j. V2 Y4 B
e7 e) [0 \ x$ W& ^2 e) x例子3:myfile.txt 中的内容如下:
! r9 P7 j4 W% @$ ?* a, _- S% this a comment
5 l- ^( V) B; h$ p% S1, 2, 3, 4' f" }# m( _. y. F& Q
5, 6, 7, 8* n' a# X5 w' R
9, 10, 11, 12' R- U$ h1 P) u% O7 c. x& Z' R
相应的语句为:4 |# r1 e# P* g5 P& a5 w3 E5 ^3 B
filename = '.\myfile.txt';5 F; a, O. C* J' w) Q7 U; C% a
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',','headerlines', 1);9 ?* F6 v4 D+ Q# ?# C- Y
这里告诉textread跳过一开始的1行,1可以替换为任意你要跳过的行数。
1 @7 e; [! x, q; d; Z7 k; M8 C8 l0 m4 ~
例子4:myfile.txt 中的内容如下:
; c2 Q7 g* ?4 l0 Y3 SSally Level1 12.34 45 Yes" Y! I* g. E" |# v0 d5 ?. s
相应语句为:- m2 L' ~, ^6 w% }1 J8 j
* r9 {6 V3 I/ M% k
filename = '.\myfile.txt'; s v D0 W& ~8 N( s
5 L u: E5 ?8 C" J[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): l5 I# r5 a0 P' E; _
%*f 告诉textread跳过一个浮点数。
/ I& x+ O, g8 ~( `% N) S& I4.2 如果要忽略Level,指读取后面的数字,, {5 u# x) k$ H" _0 g( k- f
# H( G! v& k% _( a- k. Z[names, levelnum, x, y, answer] = textread(filename , ... '%s Level%d %f %d %s', 1)例子5:myfile.txt 中的内容如下: w4 u9 L1 {/ i# w" q/ B# I9 s
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' ,';');注意:7 W0 U& [: e1 j2 Q$ V
textread不用先fopen那个文件,适用于格式统一的txt文件的一次性大批量读取。textread读取某个文件后,下次再用textread读取这个文件时,还是会从文件头开始读取。 |
zan
|