- 在线时间
- 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函数。! N! }" b# ?% N$ R1 R% o
它的基本语法是:+ f- J2 r9 k; B
[A,B,C,...] = textread(filename,format)0 L4 \' Z6 H( {
[A,B,C,...] = textread(filename,format,N)
; c4 @) V/ I6 R5 l) p) [其中filename就是文件名, format就是要读取的格式,A,B,C就是从文件中读取到的数据。
7 {8 I" n$ v, H& U中括号里面变量的个数必须和format中定义的个数相同。 如果每N行相同格式的数据,可采用[A,B,C,...] = textread(filename,format,N)的语法,读取N次。7 x6 R$ W( x6 ~
举例如下:! ~8 X" L1 N1 {6 _
例子1:myfile.txt 中的内容如下:) U" N7 g1 @3 }4 F$ {( j
1 2 3 44 ~ W: Y" M2 D' k8 @
5 6 7 8
/ U# ]" M3 u7 Y( p9 10 11 12
$ v9 X# |' k( e+ s- M相应的语句为:3 l. l. k$ J i$ }. t5 K
filename = '.\myfile.txt';
* N) O- }# X' \! i3 [; e) c[data1,data2,data3,data4]=textread(filename,'%n%n%n%n');
) k+ U. J; v- j或者为. D6 @2 L" M; W; z9 q
filename = '.\myfile.txt';: Q9 N, U3 H1 o v5 e5 D
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n',3);* _9 ^. V! W1 ^! v
4 c- f! U. s1 V) k
例子2:myfile.txt 中的内容如下:- Z8 T$ s, g8 P2 N: S- |( C
1, 2, 3, 4% X1 e0 o4 Y0 |* u4 w1 c
5, 6, 7, 8
( H9 c/ a* b) ]# s9, 10, 11, 12$ y9 \; @9 b/ u/ d3 z
相应的语句为:& V( [* m( m% T: b& ^
filename = '.\myfile.txt';
+ X9 a4 C' O b# N! j- Y7 H) r" e[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',');3 }5 Q2 \7 o1 p5 N
这里delimiter指出分隔符,读数据的时候会自动跳过分隔符。4 A6 a+ v+ y: ^3 i# u
. b+ M2 Z% l# U- Z
g1 L# d& H+ W- S+ L, W* V例子3:myfile.txt 中的内容如下:6 U9 a& q* e6 Q! q- D) ?& k. V1 b! L$ A
% this a comment
2 _% g, v# S# \1, 2, 3, 4
2 F' Q* O1 R6 \( q) t/ }5, 6, 7, 8
0 b# ~+ w* @0 l1 ?3 s0 L9, 10, 11, 12
, ?) T5 E3 E5 O) T1 w% a相应的语句为:( N! y: D1 h v* c0 O7 @
filename = '.\myfile.txt';
/ D, |# A9 h& B' _ V) J[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',','headerlines', 1);
7 ]$ Z# @( H4 v3 E* Y这里告诉textread跳过一开始的1行,1可以替换为任意你要跳过的行数。: ~* u* ?) A: S% c" R4 }% J
! b3 A& j& \+ z; {. o6 X8 s
例子4:myfile.txt 中的内容如下:
7 a6 m9 G5 X; _. NSally Level1 12.34 45 Yes
, [- B+ r6 h5 Z' I4 P相应语句为:, m% Q" n5 \. d+ J. A8 G
3 {; i6 b- E) q1 Kfilename = '.\myfile.txt';1 z% A! M; }9 p5 q- G, p# ^ S1 ^# ], E1 G
! z1 E' T5 {( H+ f+ O[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)
5 J8 T" S* o( P+ G( M2 u%*f 告诉textread跳过一个浮点数。
9 j, j! P3 F! c' v5 ?- z4.2 如果要忽略Level,指读取后面的数字,
$ `! n+ Q, {, P& a( ~
) P2 n1 Z2 c' J[names, levelnum, x, y, answer] = textread(filename , ... '%s Level%d %f %d %s', 1)例子5:myfile.txt 中的内容如下8 y4 s; { O' X: h
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' ,';');注意: G) y! f' R5 h* i; P
textread不用先fopen那个文件,适用于格式统一的txt文件的一次性大批量读取。textread读取某个文件后,下次再用textread读取这个文件时,还是会从文件头开始读取。 |
zan
|