- 在线时间
- 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,可以看到系统自带的文件特定格式的文件读取命令,常用的方法有
* w: S4 u4 H8 uxlsread,读取excel文件。
. `! @+ G& O6 e6 F! T \& ~9 Ctextread,读取txt文件等等,还有很多,有兴趣的咱们可以一起去摸索。
# t7 l( m3 p4 B. \ d( S% M, U Q另外,R2007a左右的版本,系统可以自己生成文件读取函数,只要在默认Default窗口下查看当前目录下的Current Directory,好像是Directory,记得不大清啦,这台机子上没装Matlab,就是Workspace旁边的那个框选菜单,然后双击需要读取的文件(excel格式或txt格式都可以),会弹出一个对话框,在右下角位置上有一个Great m file 选框,选中即可,就会自动生成函数啦。& H. y: H/ G& A/ b$ U: I* c
另外,给大家分享下我自己用过的几个命令: p0 y4 c/ Q! e! }
假设要读取的excel文件名为exmp.xls
2 p/ I/ k- d" h: T3 I5 S第一步,将文件放到当前文件夹里面;
) r4 I: }" B3 z4 i7 u& u第二步,写入命令) d2 j$ {2 n7 K2 V1 J g
有很多种格式 num=xlsread('exmp.xls');) C1 E& i2 W0 f
num即读取的数值文件,好像以前的有些版本只能做到这一步,我用的是R2007a版本
/ d9 U' `" g' e# {他还支持其他命令,比如:[num,txt]=xlsread('exmp.xls','sheet1'), L# s: \+ [( Q6 ]3 g5 P
num返回工作表sheet1中数值格式的内容,不是数值格式的系统默认为NaN;! R+ `0 c: A8 q& J$ B
txt返回sheet1中字符串格式的内容,以元胞的形式存储到变量txt中,同理,不是字符串格式的默认为NaN;
. U' S3 w. ^$ Z0 x# o; |. \, M: ^这样大家就很方便的进行数据写入啦。其中sheet1可以任意改为exmp内的工作表,比如'sheet2'或者你自己重命名的工作表。- y& p; ]" k" P' E* G
还有更高的
. ^5 W7 ^6 r$ ]4 l) o _+ Q[num,txt]=xlsread('exmp.xls','sheet1','A1:F81')$ A6 @) A( b4 R9 m( v' ^
num返回A1到F81矩形框中数值格式的内容
) ^: k; O; I/ b6 o2 @7 b' Ytxt返回A1到F81矩形框中字符串格式的内容
, _4 M6 |; h1 V* M; l8 i B当然矩形框大家可以根据实际需要任意定义
4 E! p( M9 {) s, k2 `% L" Q这样是不是很方便呀
, P) I; J2 t: f还有( ]" s4 q: i5 l4 y: X; S, f6 V
[num,txt,all]=xlsread('exmp.xls','sheet1')4 |$ A; \: N& p* ^8 N
all返回的是工作表sheet1中的全部内容,不过全部以元胞形式存储在all中 w& x" F0 G" s( ?& Z, ?
真想全部掌握excel文件读取功能可以用doc xlsread 命令查看帮助文档,里面讲得很详细
' K y3 T2 U. X; J N: P以前还挺喜欢用这几个命令的4 b9 K& g2 f$ q9 F. @
后来发现他有个很大的缺点,就是速度太慢,读取大的数据量时需要好几秒钟6 L) Y, W U+ T) J/ O
建议大家将数据导入txt中,用命令textread('exmp.txt'),速度会更快1 E2 f" L, p0 M& x* L
或者用fopen函数,这个可能就会麻烦一点
0 a9 q1 ]# e7 J e$ Y只是自己的一些拙见,相互学习嘛
2 _6 D& I* z% i( I2 f7 l- L5 W8 }错误的地方请大家指正,抛砖引玉就达到效果啦 |
zan
-
总评分: 体力 + 1
金币 + 2
查看全部评分
|