QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2241|回复: 0
打印 上一主题 下一主题

[课件资源] matlab的文件处理功能textread

[复制链接]
字体大小: 正常 放大

4

主题

6

听众

173

积分

升级  36.5%

  • TA的每日心情

    2012-10-25 23:22
  • 签到天数: 49 天

    [LV.5]常住居民I

    群组Matlab讨论组

    群组学术交流B

    跳转到指定楼层
    1#
    发表于 2012-7-26 21:59 |只看该作者 |正序浏览
    |招呼Ta 关注Ta
    实际应用中经常要读取txt文件,这个时候就需要用到强大的textread函数。! s: C/ O" A' Q& R' V. s. _
    它的基本语法是:
    6 o1 T! E# b! w& N: X2 P" Z[A,B,C,...] = textread(filename,format)
    8 }# a3 h  t) W: Q# S& {# s[A,B,C,...] = textread(filename,format,N)
    0 _" U* r% H0 H) g* O" B其中filename就是文件名, format就是要读取的格式,A,B,C就是从文件中读取到的数据。
    $ V' G+ `- d& d( `& a9 ^, d中括号里面变量的个数必须和format中定义的个数相同。 如果每N行相同格式的数据,可采用[A,B,C,...] = textread(filename,format,N)的语法,读取N次。  F9 _. k6 |8 a0 W2 H* Z( G
    举例如下:
    + [1 ^+ ~& o& [0 k: n例子1:myfile.txt 中的内容如下:% O, ^2 ~- j4 Y. c. B& I
    1 2 3 4
    $ O0 q6 z6 e% _% I* a  c" R5 6 7 8* b6 i: @* E+ Y! m3 Q& ^
    9 10 11 12
    ; a/ D3 d: a+ J: F# Q& A相应的语句为:
    " T7 x( ?: p' f6 lfilename = '.\myfile.txt';; m" R: c$ T3 k. ^
    [data1,data2,data3,data4]=textread(filename,'%n%n%n%n');
    % l+ L1 ~/ p. ^. I# G; M4 ?( \或者为) f. A0 M4 P! F1 P$ i0 V
    filename = '.\myfile.txt';" n; a( @# a6 s0 w1 f) M8 y
    [data1,data2,data3,data4]=textread(filename,'%n%n%n%n',3);
    ; u7 H9 R0 D1 G$ s7 p" J5 ?. z* W3 X
    例子2:myfile.txt 中的内容如下:7 ^5 L3 `$ L) T& ~6 {
    1, 2, 3, 4
    2 L: F* U0 T( E6 W5, 6, 7, 8% A" i/ M8 h& r$ ?
    9, 10, 11, 12* g) c* J( M( f1 [# H8 ]+ q9 z* f
    相应的语句为:/ E$ y/ k: e) j, I+ q+ v
    filename = '.\myfile.txt';  P2 q4 M. G2 \* ^% p: }6 \3 t& C* w
    [data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',');2 ]) @6 R4 Q$ I3 j4 w2 ?% m
    这里delimiter指出分隔符,读数据的时候会自动跳过分隔符。
    5 I* Q% p. @! h- ^# A7 K- t3 h. Y+ ^5 H: @, N  m5 o, X

    7 p( D' c+ A' `/ D& V例子3:myfile.txt 中的内容如下:
    2 q$ Z5 G( i1 }( \5 W- `% this a comment0 n5 r( e7 }. v" |: O! i; _
    1, 2, 3, 4
    ; G8 [  |: O) O% E3 ?5, 6, 7, 8: q2 j: M, A1 Y3 A. y+ T
    9, 10, 11, 12
    ) t) U' b# V2 Q( ]( m相应的语句为:1 U- U6 _% n+ e5 C4 E9 r
    filename = '.\myfile.txt';
    7 b1 M7 G* R& Z, r" `. Y2 B[data1,data2,data3,data4]=textread(filename,'%n%n%n%n','delimiter', ',','headerlines', 1);( b& P/ ?  p5 z. z* x# h5 N0 f' d; {! K
    这里告诉textread跳过一开始的1行,1可以替换为任意你要跳过的行数。
    4 P% W0 Z% z% |# S1 t
    4 L9 e+ b( A4 p$ V1 j# ^# {例子4:myfile.txt 中的内容如下:
    6 Z2 w0 F6 V$ x' G/ T9 B* D5 MSally Level1 12.34 45 Yes+ e: q* v8 X; Z+ j+ j8 U
    相应语句为:4 M7 Z: M0 }* O, O( {

    5 [6 g1 `2 f; Y8 H0 yfilename = '.\myfile.txt';1 c& f  w+ p; M# q& X% c. m
    , m; F8 N8 G$ R/ @* x! O/ 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)
    1 m% @- J" y# O  `%*f 告诉textread跳过一个浮点数。
    , y0 G8 f; W& T- g5 O! B3 L4.2 如果要忽略Level,指读取后面的数字,
    - a: w6 e7 T* Y$ a3 R# {3 c% l9 |( c: |: p0 }
    [names, levelnum, x, y, answer] = textread(filename , ... '%s Level%d %f %d %s', 1)例子5:myfile.txt 中的内容如下
    ) q% o; I6 a$ S+ q& d$ J1,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 y, K# @3 w0 T3 a- h
    textread不用先fopen那个文件,适用于格式统一的txt文件的一次性大批量读取。textread读取某个文件后,下次再用textread读取这个文件时,还是会从文件头开始读取。
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    生命在于运动
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-7-20 23:55 , Processed in 0.282504 second(s), 57 queries .

    回顶部