- 在线时间
- 0 小时
- 最后登录
- 2009-10-10
- 注册时间
- 2009-7-18
- 听众数
- 9
- 收听数
- 0
- 能力
- 0 分
- 体力
- 104 点
- 威望
- 11 点
- 阅读权限
- 30
- 积分
- 271
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 235
- 主题
- 19
- 精华
- 1
- 分享
- 0
- 好友
- 0
升级 85.5% 该用户从未签到
|
Matlab功能真的很强大,数据接口做得也相当完美,和大家分享下自己文件读取方面的一些收获和体会吧。Matlab文件导入的函数很多,可以用doc命令打开帮助文档,在search栏里面输入?read查找,不过这样比较盲目,或者用help ?read,可以看到系统自带的文件特定格式的文件读取命令,常用的方法有
]% {- j. }# {6 f$ Xxlsread,读取excel文件。
+ V' x0 E3 }+ I- W5 Z, y: t/ j6 itextread,读取txt文件等等,还有很多,有兴趣的咱们可以一起去摸索。2 ?% R! {' M( A3 }& a1 W( q& n
另外,R2007a左右的版本,系统可以自己生成文件读取函数,只要在默认Default窗口下查看当前目录下的Current Directory,好像是Directory,记得不大清啦,这台机子上没装Matlab,就是Workspace旁边的那个框选菜单,然后双击需要读取的文件(excel格式或txt格式都可以),会弹出一个对话框,在右下角位置上有一个Great m file 选框,选中即可,就会自动生成函数啦。
2 V) _2 T9 r @/ Z7 h另外,给大家分享下我自己用过的几个命令) n0 U7 @' Y* @% b1 l& k9 {
假设要读取的excel文件名为exmp.xls: H( {6 @! N- D
第一步,将文件放到当前文件夹里面;
$ K2 H/ j& g y( U% N4 |; ?9 D0 }第二步,写入命令
6 x9 k1 F F) ^# n) b5 Z有很多种格式 num=xlsread('exmp.xls');
% j. ?: x4 Q9 {: Q# ~0 m! cnum即读取的数值文件,好像以前的有些版本只能做到这一步,我用的是R2007a版本
$ o& p& y6 T" E. R7 b. }他还支持其他命令,比如:[num,txt]=xlsread('exmp.xls','sheet1')
+ |5 Z3 p9 r! B% r. H$ v& p$ Cnum返回工作表sheet1中数值格式的内容,不是数值格式的系统默认为NaN;
6 G: C! v9 ~7 G1 V3 t; i2 E4 ptxt返回sheet1中字符串格式的内容,以元胞的形式存储到变量txt中,同理,不是字符串格式的默认为NaN;
: f q% U I9 R4 X* u8 x, a- Q这样大家就很方便的进行数据写入啦。其中sheet1可以任意改为exmp内的工作表,比如'sheet2'或者你自己重命名的工作表。
) q3 k* H0 O; z) i" T还有更高的- V5 K4 H/ J, ?; n
[num,txt]=xlsread('exmp.xls','sheet1','A1:F81')- ]6 C. v% G7 u2 u+ n* s" B6 l
num返回A1到F81矩形框中数值格式的内容
( ~2 ]& K2 H5 T' |. r/ {txt返回A1到F81矩形框中字符串格式的内容. Z; |9 @9 N) k0 _3 ~: s7 c6 y; G
当然矩形框大家可以根据实际需要任意定义 B$ j( O: V& Z) K' ~# j) E3 j1 k
这样是不是很方便呀5 F. a: u' V/ K9 a- I& u
还有2 |* L2 w" }5 E, f* L7 n
[num,txt,all]=xlsread('exmp.xls','sheet1'), B: J' j- j( x! L; E: @. f
all返回的是工作表sheet1中的全部内容,不过全部以元胞形式存储在all中
% z5 w, ~ X1 y, U4 u真想全部掌握excel文件读取功能可以用doc xlsread 命令查看帮助文档,里面讲得很详细: A; q S b* k0 m) o8 i- z; A
以前还挺喜欢用这几个命令的1 P6 A# ]4 `$ } |7 Z
后来发现他有个很大的缺点,就是速度太慢,读取大的数据量时需要好几秒钟
h9 v# X# x! N" T建议大家将数据导入txt中,用命令textread('exmp.txt'),速度会更快$ G% ~# M- Z+ r! U# ?: {' S) f
或者用fopen函数,这个可能就会麻烦一点
% w# Z8 u5 X5 s; p只是自己的一些拙见,相互学习嘛0 Q9 p9 v0 g. z' P% X( K% i. h
错误的地方请大家指正,抛砖引玉就达到效果啦 |
zan
-
总评分: 体力 + 1
金币 + 2
查看全部评分
|