- 在线时间
- 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 h8 [' ~# \" R% l
它的基本语法是:2 m3 F1 {$ g" G' Q/ I" C
[A,B,C,...] = textread(filename,format)
9 G$ ^( O1 r6 b1 Q[A,B,C,...] = textread(filename,format,N)
z; [- p! t2 k) j0 b8 g其中filename就是文件名, format就是要读取的格式,A,B,C就是从文件中读取到的数据。
# ^# z7 r' y* z- j, t中括号里面变量的个数必须和format中定义的个数相同。 如果每N行相同格式的数据,可采用[A,B,C,...] = textread(filename,format,N)的语法,读取N次。
- a q' z5 j) |( W( g2 y. U+ e9 w举例如下:
6 b. N/ a; }+ D" u, ~例子1:myfile.txt 中的内容如下:7 p# v( W p$ Y: L8 f7 Y6 F
1 2 3 4
4 B' k7 l5 |; U* p6 w5 6 7 8
( f0 y, n+ b4 g% y9 ~) {& G e9 10 11 12
5 `7 {2 N8 a$ ]' J6 d( g1 E/ @9 s相应的语句为:6 U4 }, g# ^7 a. ^& ~
filename = '.\myfile.txt';5 H7 Z9 e# I: {" K, B% K
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n');
w r( h- P! R2 W或者为0 f+ c( p$ \' g$ @2 \% K
filename = '.\myfile.txt';6 X! Q/ T: |7 Y! d% K
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n',3);( P% Z1 | ~; T, P
3 t7 _" w s/ {3 A3 c* z
例子2:myfile.txt 中的内容如下:* x3 B" E3 n, h
1, 2, 3, 40 x; A( F+ [$ O. g7 ?! @* J
5, 6, 7, 8
E# r' [" C3 f2 Y! t+ C9, 10, 11, 12
% [. F. M' j! M5 J' S% C/ K# n1 h相应的语句为:
5 _. [# w4 l sfilename = '.\myfile.txt';/ G: v! M" ~+ @6 J
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',');
6 W" I2 ~+ E% B) _' ?) ?这里delimiter指出分隔符,读数据的时候会自动跳过分隔符。
- }( `1 n8 u1 ~7 Q) _8 `$ j* d
) ~# q! I# ?5 L8 N1 h0 p( M8 U
例子3:myfile.txt 中的内容如下:$ |4 ~; k/ m# [' _
% this a comment
7 y( t: b# Z5 V+ u7 R1, 2, 3, 4
: B0 E n" }4 K6 S% E5, 6, 7, 8
* B. p! F1 n4 R& I" p. l2 E9, 10, 11, 12
# F( m, z' T: A/ v9 f相应的语句为: P- E) X d$ [; J) c3 [4 X' A
filename = '.\myfile.txt';+ u3 U& I, E& [+ y% U6 n
[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',','headerlines', 1);: Y7 H4 h/ W: ]4 ~) K/ d/ U# A
这里告诉textread跳过一开始的1行,1可以替换为任意你要跳过的行数。
2 D9 q7 o t4 n+ A9 m/ Z6 ~) }( Z" D# K) v( q4 z: \$ ~; W
例子4:myfile.txt 中的内容如下:
F! W- T: n: ~4 v, eSally Level1 12.34 45 Yes
. t3 Y) l; \2 P相应语句为:4 U, g* W8 e5 V! i
$ @4 p9 p' c& q. e' T8 r5 `8 kfilename = '.\myfile.txt';6 E1 B/ \% x' w9 D
" h3 `, ]6 Q/ G
[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)9 ~$ V# X% N! e
%*f 告诉textread跳过一个浮点数。
" H0 d+ |* X# p. g2 R4.2 如果要忽略Level,指读取后面的数字,
& X# Q9 a9 N( N' [' C- D7 R8 }* `3 F' E- x& Z+ A; u0 ]1 f
[names, levelnum, x, y, answer] = textread(filename , ... '%s Level%d %f %d %s', 1)例子5:myfile.txt 中的内容如下
, A% V, K5 Y) [% N9 W9 X' t1,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' ,';');注意: C' R* D$ R# o- w+ `9 }0 S
textread不用先fopen那个文件,适用于格式统一的txt文件的一次性大批量读取。textread读取某个文件后,下次再用textread读取这个文件时,还是会从文件头开始读取。 |
zan
|