数学建模社区-数学中国

标题: Matlab数据导入之我见 [打印本页]

作者: xiaobingforever    时间: 2009-8-20 12:58
标题: Matlab数据导入之我见
Matlab功能真的很强大,数据接口做得也相当完美,和大家分享下自己文件读取方面的一些收获和体会吧。Matlab文件导入的函数很多,可以用doc命令打开帮助文档,在search栏里面输入?read查找,不过这样比较盲目,或者用help ?read,可以看到系统自带的文件特定格式的文件读取命令,常用的方法有' ?) F, G; p  Y3 M: D  F+ n
xlsread,读取excel文件。
! G4 `) F, d) X9 h* gtextread,读取txt文件等等,还有很多,有兴趣的咱们可以一起去摸索。( @6 p0 ~# ~. u* m( I- g
另外,R2007a左右的版本,系统可以自己生成文件读取函数,只要在默认Default窗口下查看当前目录下的Current Directory,好像是Directory,记得不大清啦,这台机子上没装Matlab,就是Workspace旁边的那个框选菜单,然后双击需要读取的文件(excel格式或txt格式都可以),会弹出一个对话框,在右下角位置上有一个Great m file 选框,选中即可,就会自动生成函数啦。# m& @6 L8 c) z- [: [
另外,给大家分享下我自己用过的几个命令5 M9 h" _0 d7 |5 J" c1 |
假设要读取的excel文件名为exmp.xls
. U/ \! y% F" C) k. h3 ^第一步,将文件放到当前文件夹里面;, {. r2 Z5 p4 d  J" j5 c4 S4 O$ E
第二步,写入命令* B7 q$ H5 B, X3 \3 m4 A' O
有很多种格式 num=xlsread('exmp.xls');5 L9 j9 O, w% G4 t7 |) c( e8 G
num即读取的数值文件,好像以前的有些版本只能做到这一步,我用的是R2007a版本
* P( L8 e) i# D4 J' F& Y( a9 E  ], T他还支持其他命令,比如:[num,txt]=xlsread('exmp.xls','sheet1')
# y# K5 J) G$ u, K. M4 `" U4 |num返回工作表sheet1中数值格式的内容,不是数值格式的系统默认为NaN;
8 Z: Q8 [2 t. J/ d  Ztxt返回sheet1中字符串格式的内容,以元胞的形式存储到变量txt中,同理,不是字符串格式的默认为NaN;
8 j. x" J9 o1 i) f' }4 t7 _) S& I4 V这样大家就很方便的进行数据写入啦。其中sheet1可以任意改为exmp内的工作表,比如'sheet2'或者你自己重命名的工作表。3 o" w9 G1 K- `0 m1 y
还有更高的
: p# L& p4 e) G) q( r[num,txt]=xlsread('exmp.xls','sheet1','A1:F81')7 O$ X' d+ M/ l; S
num返回A1到F81矩形框中数值格式的内容
3 j% ]3 _$ ^* s/ V/ y; ]! S0 ?txt返回A1到F81矩形框中字符串格式的内容  Y: D" _6 S+ b% n, C
当然矩形框大家可以根据实际需要任意定义8 S' J* B8 P6 b+ j  [
这样是不是很方便呀6 z  j. p$ t. }
还有
- q5 B! g9 f( e. E4 R1 s[num,txt,all]=xlsread('exmp.xls','sheet1')4 [6 U8 K) j( j% w
all返回的是工作表sheet1中的全部内容,不过全部以元胞形式存储在all中* j7 g& f; P# V# X8 m+ M
真想全部掌握excel文件读取功能可以用doc xlsread 命令查看帮助文档,里面讲得很详细
! B4 y( [& M  J; i以前还挺喜欢用这几个命令的$ K4 ]/ c; U( k2 G3 Y1 f0 n( v
后来发现他有个很大的缺点,就是速度太慢,读取大的数据量时需要好几秒钟2 B0 W" w5 |9 h4 G  I. z1 {
建议大家将数据导入txt中,用命令textread('exmp.txt'),速度会更快
* \' I/ Z6 s1 o3 i. M: V% N或者用fopen函数,这个可能就会麻烦一点
/ _- U* o& D3 Q2 }! C! T只是自己的一些拙见,相互学习嘛
7 O8 t9 j% L9 h5 p错误的地方请大家指正,抛砖引玉就达到效果啦
作者: jyh123    时间: 2009-8-20 14:30
好东东啊!
作者: 东方明珠-WDZYQ    时间: 2009-8-20 14:31
好的,这样的分享能够营造气氛啊
作者: w13king    时间: 2009-8-20 15:19
很好的东西!
作者: hnluoyang123    时间: 2009-8-20 15:27
不要企图爱上我,哥只是个传说。
作者: 你的优乐美    时间: 2009-8-20 15:36
学习一下     呵呵    谢谢
作者: 一直很执着    时间: 2009-8-20 16:17
我正要找呢,呵呵,谢谢啦~~9 G9 q, [2 _7 @# U! h+ t
顺便请教一下,如何把word里的数据导入excel呢
作者: ykl126    时间: 2009-8-20 18:02
小生在此谢过了。
作者: zsuzengli    时间: 2009-8-20 18:24
不错的东西
作者: tk595241035    时间: 2009-8-20 19:20
很不错的帖子,突然发现这论坛对建模的人来说真的太好了~~
作者: pengxiangda    时间: 2009-8-20 20:04
好东西!又是原创,坚决支持!
作者: xiaobingforever    时间: 2009-8-20 22:18
不好意思,Office我用得并不好,Word数据导入excel一般都是用的复制粘贴。希望有会的朋友一起分享,谢谢大家的鼓励。
作者: yuejl    时间: 2009-8-20 22:24
好东西啊。。。。
作者: mrx    时间: 2009-8-21 06:17
matlab 里的主成分分析.rar (864 Bytes, 下载次数: 4)

关于校车安排问题.rar

669 Bytes, 下载次数: 0, 下载积分: 体力 -2 点

火车票全程对号销售系统优化研究.rar

634 Bytes, 下载次数: 0, 下载积分: 体力 -2 点

金融风暴下快餐连锁企业的促销推广策略.rar

1.05 KB, 下载次数: 0, 下载积分: 体力 -2 点

蚁群算法的基本原理.rar

2.55 KB, 下载次数: 0, 下载积分: 体力 -2 点


作者: xczxtxy    时间: 2009-8-21 08:30
很不错的帖子,突然发现这论坛对建模的人来说真的太好了~~
作者: xczxtxy    时间: 2009-8-21 08:31
不错的东西
作者: xczxtxy    时间: 2009-8-21 08:31
小生在此谢过了。
作者: liuyaliss    时间: 2009-8-21 09:07
学习一下··
作者: 东方明珠-WDZYQ    时间: 2009-8-24 09:12
有意思啊 呵呵
作者: ywt    时间: 2009-8-24 10:56
好东西,太感谢了
作者: 21881022    时间: 2009-8-24 11:21
首先谢谢楼主,我想问一个问题,怎样自动导入excel文件的所有数据。例如,excel文件有多个sheet窗口,需要自动导入所有窗口的数据怎么导?
作者: jdzzhan    时间: 2009-8-24 22:42
学到了一招 谢谢,我都试过了,很好
作者: daiqiang5566    时间: 2009-8-25 15:18
mark mark mark;
作者: sisi_bupt    时间: 2009-8-25 16:35
好帖,谢谢!/ E, s3 i0 t1 w: A" E! v
请问关于图像文件的读取有没有什么比较好用的方法?
作者: mine_12    时间: 2009-8-25 19:06
好好学习学习!
作者: zdshitiaogou    时间: 2009-8-25 21:49
谢谢了。好东西
作者: ywt    时间: 2009-8-30 12:21
说的太好了……
作者: 巴西木    时间: 2009-8-30 13:46
很实用的东东啊~
作者: xiaobingforever    时间: 2009-8-30 13:55
21# 21881022
9 E8 c& o" b: E: i3 _" ~  q所有数据导入好像用importdata可行
+ Q4 R2 |6 ?! \& i0 f返回一个结构体变量" F9 W8 @( N' u, s( w2 ^* J5 q# c
每一个工作表是一个域 也可以分文本域数值# R: x! I: G6 \$ i7 z% Y2 T
具体请参考
/ T6 {0 x0 P* f$ O3 Ohttp://www.madio.cn/mcm/thread-31214-1-1.html
作者: xiaobingforever    时间: 2009-8-30 13:58
24# sisi_bupt , Y: t2 D1 j& m0 O
这个就不好说啦8 {2 k  k+ A$ B+ z
英爱应该数MATLAB图像处理的内容; G; Y1 x( {( k5 n7 j
一般是用imread吧- m8 F4 a4 V# M6 ?
生成一个3维int8类型的数组# Y. T5 B0 X& J. x: B3 W! F: F
每一个像素点对应一个坐标值
- _$ N2 l; H+ J" ]6 k2 t可以通过函数变成灰度图
0 S5 Z& s! q6 y+ D- ~或者通过pixval查看具体值吧
2 W9 x! k# a( J这个懂得不是很多
作者: lirui0081    时间: 2009-8-30 16:06
很不错的哟~!
作者: yzy364972    时间: 2009-8-30 17:08
如何把word里的数据导入excel呢
作者: handsome8848    时间: 2009-8-30 19:16

5 N3 l, V- [+ I/ j支持,导入数据我一般是用复制+赋值的~~
) C( h( R( }9 m0 }/ h- o7 k7 CLZ的方法很好
作者: hjsqxgb2009    时间: 2009-8-31 00:00
嗯嗯,我也喜欢!!
作者: gxj820    时间: 2009-8-31 09:36
很好啊 !!顶顶
作者: 阿芳    时间: 2009-8-31 11:03
谢谢啦,正需要呢
作者: pigyoung    时间: 2009-8-31 11:38
不是可以import data吗??
作者: 小小雨112233    时间: 2009-8-31 14:08
谢论坛管理员  真的辛苦啦  为了广大的同学们服务!!!谢谢啦
作者: zhangyunlong    时间: 2009-8-31 14:20
谢谢lZ了 学习一下
作者: byit    时间: 2009-8-31 14:33
这个主题好。
作者: zhisony123    时间: 2009-8-31 14:55
实在是非常强大
作者: 遗忘    时间: 2009-8-31 14:57
非常感谢啊!
作者: sisi_bupt    时间: 2009-8-31 15:14
很有用哦……谢谢!
作者: gxj820    时间: 2009-8-31 15:28
真的是很好的东西哈!
作者: xiaobingforever    时间: 2009-8-31 18:08
37# pigyoung
) `, s. m0 I, q8 G0 M
6 F; K; g. E/ I2 [/ himportdata也很强大
作者: 占领王    时间: 2009-8-31 19:03
积 极 讨 论。。。
作者: casinoroyale    时间: 2009-9-1 10:59
很好很强大
作者: 大笨象    时间: 2009-9-1 12:53
呵呵。学习一下了。有用。
作者: HSinB    时间: 2009-9-1 14:37
好东西啊!!!
作者: fangxianghui    时间: 2009-9-1 18:05
1# xiaobingforever
: b8 R% R9 n% h4 s# c很好呀!谢谢楼主!
作者: kekexili81    时间: 2009-9-7 19:18
伟哥,加油
作者: lhx2103852    时间: 2009-9-7 19:28
谢楼主~~~~
作者: linspirit    时间: 2009-9-13 09:42
我最需要了,谢谢! 1# xiaobingforever
作者: linspirit    时间: 2009-9-13 09:43
谢谢! 53# linspirit
作者: lilinbluesky    时间: 2009-9-13 10:02
感谢楼主分享
作者: zcilly    时间: 2009-12-4 14:28
呵呵,这些都会,其实最快的是用data input 把数据转化为matlab的格式,不过就是有点麻烦
9 F9 i7 n" q2 P( T! c另外xlsread 其实还是可以用,就是第一次导入数据的时候有点慢,个人觉得这个接口还是可以的,前提是机子好的话
, H, ?; c) j6 M" z6 i; xtextread嘛,速度可以,但是因为我们本身就不常用,不大熟悉text,所以我不常用textread命令
7 j  K: P1 f8 U, O- T我个人觉得fopen函数还是可以的,呵呵
作者: 大笨象    时间: 2009-12-7 12:34
一个很不错的帖子。
作者: shuaiyi    时间: 2009-12-7 12:36
呵呵……是得熟练最基本的操作。可以找本专业的书看看。
作者: 枫露之茗    时间: 2009-12-29 12:54
好东西,大家分享,精神可嘉% q; f4 h# B* H  j
!!!!!!!!
作者: mnpfc    时间: 2010-1-5 14:39
谢谢分享!!!!!!!!!!!!!!!!!!!!!!!
作者: licoro    时间: 2010-1-7 15:22
回复 2# jyh123
* a: J6 e+ |8 K' ]; o
: x, d" b5 T( q, p# n0 ^1 S, Y0 ?; X/ M! [+ v. E! F$ Q% a
    好呀!!!
作者: 彩虹天堂    时间: 2010-1-9 18:25
回复 1# xiaobingforever 6 N' v" C6 a. p- F& r; J+ a7 r5 v) m
( c: d+ P6 E0 t
8 P7 z( ]# H* _
    好东西
作者: starbinbin    时间: 2010-1-10 15:23
我顶你,写的很好很精炼!谢谢了!
作者: qimeng596    时间: 2010-2-3 18:56
学习....谢谢....分享......谢谢............同勉..
作者: yyz895    时间: 2010-2-3 19:02
东西很不错!谢谢………………………………………………………………
作者: yyz895    时间: 2010-2-3 19:03
太感谢了…………………………………………………………
作者: yyz895    时间: 2010-2-3 19:07
真的很不错!再顶一下……………………………………………………
作者: diguaaiqianqian    时间: 2010-2-3 22:28
我曾经试过几次,都没成功,现在知道原因了。
作者: legan    时间: 2010-2-7 13:29
我前几天正为导入数据的问题而发愁呢,不过后来我自己解决了,现在看到你的这篇文章,感觉我自己的matlab水平真的是太烂了,还要好好努力哈
作者: rvlfly    时间: 2010-2-14 20:11
Very Good!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
作者: yangcsuchuan    时间: 2010-8-5 13:13
顶。。。。。。。。。。。。。
作者: RTaylor    时间: 2011-1-10 11:28
哪里有视频指导?
作者: 39133120    时间: 2011-2-13 19:44
好,真经验!
作者: 弟雨73    时间: 2011-6-17 13:47
不错的帖子,学习
作者: 撒旦之父    时间: 2011-6-25 22:14
用法是相同的。
作者: alair005    时间: 2012-2-6 15:52
3x,you are so great1860135258335900
作者: mj1259389904    时间: 2013-9-9 19:53
高级啊,谢谢楼主
作者: Meteor胖号    时间: 2013-9-10 09:38
bucuobucuo
作者: 大國崛起    时间: 2014-8-12 10:33
好的,这样的分享能够营造气氛啊
作者: Zhang_Jiaxing    时间: 2015-1-17 19:04
竟然还有这用法
3 L9 D- p/ ^1 b8 m* a/ n4 @
作者: 鸣凤123    时间: 2015-8-14 20:15
楼主的帖子很不错,我觉得很有用1 r  }: @3 B! e1 v

作者: 421018735    时间: 2019-1-4 15:08
一点个人看法7 b! N3 q3 m5 I. D/ Y) k' X

作者: 2286773557    时间: 2020-2-12 14:02
对新手帮助蛮大的 谢谢楼主" ^4 F9 x) C3 j& s





欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5