- 在线时间
- 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,可以看到系统自带的文件特定格式的文件读取命令,常用的方法有/ Y& J$ s) G7 c, v( ~* s
xlsread,读取excel文件。
3 Z6 `4 `9 l6 |9 Ktextread,读取txt文件等等,还有很多,有兴趣的咱们可以一起去摸索。( b0 `! N' X" m. {# g* M3 ]+ I
另外,R2007a左右的版本,系统可以自己生成文件读取函数,只要在默认Default窗口下查看当前目录下的Current Directory,好像是Directory,记得不大清啦,这台机子上没装Matlab,就是Workspace旁边的那个框选菜单,然后双击需要读取的文件(excel格式或txt格式都可以),会弹出一个对话框,在右下角位置上有一个Great m file 选框,选中即可,就会自动生成函数啦。( i# J0 @- F$ A5 u. _( }# ~# K- ^
另外,给大家分享下我自己用过的几个命令( Q: N* V6 W% |7 k" S
假设要读取的excel文件名为exmp.xls% A; W7 ^( H" i
第一步,将文件放到当前文件夹里面;$ X4 ^1 D, i5 H- O9 S
第二步,写入命令
% w% N, u* F( J. g- v$ q有很多种格式 num=xlsread('exmp.xls');7 v' M9 L' [7 f/ _/ w# P4 K
num即读取的数值文件,好像以前的有些版本只能做到这一步,我用的是R2007a版本( r; i! x# T3 q2 o
他还支持其他命令,比如:[num,txt]=xlsread('exmp.xls','sheet1')* l4 P- i2 q) \) n" g' u
num返回工作表sheet1中数值格式的内容,不是数值格式的系统默认为NaN;" q8 O1 G; x5 r2 k6 `5 ]. C
txt返回sheet1中字符串格式的内容,以元胞的形式存储到变量txt中,同理,不是字符串格式的默认为NaN;
9 }- C9 V& a) \ ?* V3 a; Y这样大家就很方便的进行数据写入啦。其中sheet1可以任意改为exmp内的工作表,比如'sheet2'或者你自己重命名的工作表。
& T f: }- O2 l0 ^; \. n2 e* U还有更高的
1 _) F0 V+ u2 z/ S6 A( J[num,txt]=xlsread('exmp.xls','sheet1','A1:F81')
0 x- O+ U& ] c5 I. q- O' Rnum返回A1到F81矩形框中数值格式的内容
8 V/ A; h% H5 L+ Z0 Xtxt返回A1到F81矩形框中字符串格式的内容7 F7 O" S$ M: s9 o3 f; R5 [$ t
当然矩形框大家可以根据实际需要任意定义; ~6 G* w, D% f2 @' O
这样是不是很方便呀
# ]# V: S5 `+ |7 }3 H& Y. |还有1 W e- e: T! J6 x- ^; d
[num,txt,all]=xlsread('exmp.xls','sheet1'), v1 [) U& W( T9 I/ h- g3 L
all返回的是工作表sheet1中的全部内容,不过全部以元胞形式存储在all中6 @- b$ v3 H8 v4 ]
真想全部掌握excel文件读取功能可以用doc xlsread 命令查看帮助文档,里面讲得很详细: R1 E* S1 _: L9 V$ a! K2 T
以前还挺喜欢用这几个命令的. Z" n7 c5 ~8 ?5 i
后来发现他有个很大的缺点,就是速度太慢,读取大的数据量时需要好几秒钟
8 A- W2 h/ l% @建议大家将数据导入txt中,用命令textread('exmp.txt'),速度会更快
2 g( X* s+ L7 a( Z$ A或者用fopen函数,这个可能就会麻烦一点2 o( {! }3 ~7 e% p" p
只是自己的一些拙见,相互学习嘛
% V3 Y* [! ~9 N2 e2 @) y/ Y错误的地方请大家指正,抛砖引玉就达到效果啦 |
zan
-
总评分: 体力 + 1
金币 + 2
查看全部评分
|