- 在线时间
- 0 小时
- 最后登录
- 2009-10-10
- 注册时间
- 2009-7-18
- 听众数
- 9
- 收听数
- 0
- 能力
- 0 分
- 体力
- 104 点
- 威望
- 11 点
- 阅读权限
- 30
- 积分
- 271
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 234
- 主题
- 19
- 精华
- 1
- 分享
- 0
- 好友
- 0
升级   85.5% 该用户从未签到
 |
Matlab功能真的很强大,数据接口做得也相当完美,和大家分享下自己文件读取方面的一些收获和体会吧。Matlab文件导入的函数很多,可以用doc命令打开帮助文档,在search栏里面输入?read查找,不过这样比较盲目,或者用help ?read,可以看到系统自带的文件特定格式的文件读取命令,常用的方法有& \3 o4 M; t9 V" l5 W0 @
xlsread,读取excel文件。- Z, M* f8 S! d( E% j# q
textread,读取txt文件等等,还有很多,有兴趣的咱们可以一起去摸索。! c8 e) L; ^4 J( _$ G' i3 Z
另外,R2007a左右的版本,系统可以自己生成文件读取函数,只要在默认Default窗口下查看当前目录下的Current Directory,好像是Directory,记得不大清啦,这台机子上没装Matlab,就是Workspace旁边的那个框选菜单,然后双击需要读取的文件(excel格式或txt格式都可以),会弹出一个对话框,在右下角位置上有一个Great m file 选框,选中即可,就会自动生成函数啦。- A" q6 ~/ n! A5 ~+ x
另外,给大家分享下我自己用过的几个命令: M8 p! J% t6 J% M7 R/ m
假设要读取的excel文件名为exmp.xls h" d: a1 \8 ?4 J' ]9 p- v! l8 j
第一步,将文件放到当前文件夹里面;
9 H" A- q2 A1 f. E& `+ q m第二步,写入命令
; j) ~: X$ K& T; h" r8 V有很多种格式 num=xlsread('exmp.xls');
, I: B, y; H* Tnum即读取的数值文件,好像以前的有些版本只能做到这一步,我用的是R2007a版本) v9 I6 Y% G7 ^) S. c6 ~
他还支持其他命令,比如:[num,txt]=xlsread('exmp.xls','sheet1')3 i' ~3 m/ t; V. j0 e
num返回工作表sheet1中数值格式的内容,不是数值格式的系统默认为NaN;# G& j, i, { r( m ~: \' W- c2 K
txt返回sheet1中字符串格式的内容,以元胞的形式存储到变量txt中,同理,不是字符串格式的默认为NaN;
( ?% c( ]! P7 m* W# T! I! E这样大家就很方便的进行数据写入啦。其中sheet1可以任意改为exmp内的工作表,比如'sheet2'或者你自己重命名的工作表。
6 b3 o. U0 N# o* x还有更高的
1 D2 q" v! x+ u; w$ n[num,txt]=xlsread('exmp.xls','sheet1','A1:F81')7 h3 y% x; z5 M+ J' ?+ I8 p
num返回A1到F81矩形框中数值格式的内容: _0 h5 s% h8 A! s: I5 D
txt返回A1到F81矩形框中字符串格式的内容
5 L3 x3 h8 S3 o; V当然矩形框大家可以根据实际需要任意定义
3 T/ N- W5 D- M% l4 w2 h' {# d" F! m这样是不是很方便呀
" g* s* |8 w: S: d7 g5 P还有: g% D: P+ r. m# k( Q7 ?
[num,txt,all]=xlsread('exmp.xls','sheet1')
: y# l7 |6 Q6 ^0 G7 q2 ball返回的是工作表sheet1中的全部内容,不过全部以元胞形式存储在all中, Y$ B ?; H& l
真想全部掌握excel文件读取功能可以用doc xlsread 命令查看帮助文档,里面讲得很详细
$ w. E% j( p$ w& m8 g以前还挺喜欢用这几个命令的4 T k+ B9 |% s$ T* d3 b+ } }
后来发现他有个很大的缺点,就是速度太慢,读取大的数据量时需要好几秒钟0 w! i# Q& z8 b4 ~( M* ~/ h( F
建议大家将数据导入txt中,用命令textread('exmp.txt'),速度会更快
1 B1 u+ ?6 Y( I3 r' E( R- {或者用fopen函数,这个可能就会麻烦一点
: x0 T, L; v% t) ~只是自己的一些拙见,相互学习嘛( q% s* R% Z, z; @* v
错误的地方请大家指正,抛砖引玉就达到效果啦 |
zan
-
总评分: 体力 + 1
金币 + 2
查看全部评分
|