数学建模社区-数学中国

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

作者: xiaobingforever    时间: 2009-8-20 12:58
标题: Matlab数据导入之我见
Matlab功能真的很强大,数据接口做得也相当完美,和大家分享下自己文件读取方面的一些收获和体会吧。Matlab文件导入的函数很多,可以用doc命令打开帮助文档,在search栏里面输入?read查找,不过这样比较盲目,或者用help ?read,可以看到系统自带的文件特定格式的文件读取命令,常用的方法有% T/ }$ W' J- l' o
xlsread,读取excel文件。8 }) C8 E2 y6 w! x- e
textread,读取txt文件等等,还有很多,有兴趣的咱们可以一起去摸索。4 t+ k- q9 x; x5 h9 L# X2 \
另外,R2007a左右的版本,系统可以自己生成文件读取函数,只要在默认Default窗口下查看当前目录下的Current Directory,好像是Directory,记得不大清啦,这台机子上没装Matlab,就是Workspace旁边的那个框选菜单,然后双击需要读取的文件(excel格式或txt格式都可以),会弹出一个对话框,在右下角位置上有一个Great m file 选框,选中即可,就会自动生成函数啦。
: ?" z3 D3 i: `1 j  ~+ e, m* V另外,给大家分享下我自己用过的几个命令% m. y6 {/ B7 o0 J7 P
假设要读取的excel文件名为exmp.xls$ p, Z) k) c( j( Q2 ^
第一步,将文件放到当前文件夹里面;! a) c8 W9 r5 y2 a
第二步,写入命令
' ]$ W5 d4 f% a* m/ b有很多种格式 num=xlsread('exmp.xls');) E/ t2 J/ P/ M( z$ z- }0 r
num即读取的数值文件,好像以前的有些版本只能做到这一步,我用的是R2007a版本9 y1 n; c( k' s+ N% {0 W6 \
他还支持其他命令,比如:[num,txt]=xlsread('exmp.xls','sheet1')) O$ E6 l" y1 I4 w5 R
num返回工作表sheet1中数值格式的内容,不是数值格式的系统默认为NaN;
0 C" A" }/ w2 P' X8 s/ otxt返回sheet1中字符串格式的内容,以元胞的形式存储到变量txt中,同理,不是字符串格式的默认为NaN;, v0 |3 o: N" l- R  M
这样大家就很方便的进行数据写入啦。其中sheet1可以任意改为exmp内的工作表,比如'sheet2'或者你自己重命名的工作表。. j) j+ ?. A8 ~3 H6 B! ~6 S
还有更高的
/ U; |; [  R7 ^5 q/ |, c' r! R[num,txt]=xlsread('exmp.xls','sheet1','A1:F81')/ G/ B- N( g7 m9 A6 y# z2 t6 q
num返回A1到F81矩形框中数值格式的内容
3 ]5 k! c3 r- h& P" ~txt返回A1到F81矩形框中字符串格式的内容
3 }$ L! M6 t/ |& q( p) d5 I当然矩形框大家可以根据实际需要任意定义
+ N/ ^0 c! Q# o6 h0 c7 n2 m+ q% S这样是不是很方便呀
: n1 K! ~# C" z/ ?还有' v: k7 _$ j0 ^9 O6 m, M% A
[num,txt,all]=xlsread('exmp.xls','sheet1')9 [2 X; X! C  V' S& M3 p7 K3 |
all返回的是工作表sheet1中的全部内容,不过全部以元胞形式存储在all中  X- }7 Y6 m2 x
真想全部掌握excel文件读取功能可以用doc xlsread 命令查看帮助文档,里面讲得很详细
, M/ i  m# w/ F  W2 A- D$ I以前还挺喜欢用这几个命令的
. \9 U1 d  b! G后来发现他有个很大的缺点,就是速度太慢,读取大的数据量时需要好几秒钟; i6 J- }1 N1 C2 A# \" E
建议大家将数据导入txt中,用命令textread('exmp.txt'),速度会更快( ~" Q3 Y' {# a* p; n( v
或者用fopen函数,这个可能就会麻烦一点( S. W# k% I& j
只是自己的一些拙见,相互学习嘛- x& R4 c; s2 t0 w* E- W
错误的地方请大家指正,抛砖引玉就达到效果啦
作者: 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
我正要找呢,呵呵,谢谢啦~~
6 x1 x' Z" h( q% r' U$ n1 l顺便请教一下,如何把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
好帖,谢谢!
9 O/ m% E9 V+ F请问关于图像文件的读取有没有什么比较好用的方法?
作者: 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 & |- _+ W: u6 J; e/ ]+ l( m0 B6 {9 V5 y
所有数据导入好像用importdata可行
. D: g7 ^* c5 e' g" d* y返回一个结构体变量
4 j9 h' n  X5 F1 Q9 \, O每一个工作表是一个域 也可以分文本域数值
$ H6 Y& Z) C% C: s5 Q0 q具体请参考) {2 w9 N1 n" W9 j
http://www.madio.cn/mcm/thread-31214-1-1.html
作者: xiaobingforever    时间: 2009-8-30 13:58
24# sisi_bupt 3 ^; x' R- A  a" K; t' d2 c
这个就不好说啦
# K; M4 h" A& a1 @1 U& d. d8 O英爱应该数MATLAB图像处理的内容3 H# H5 X& h9 @+ D2 H! U( Z8 X- e  h
一般是用imread吧
( d" |" ^7 T- e生成一个3维int8类型的数组
. s7 I( v4 p: y9 h! b每一个像素点对应一个坐标值
0 R9 p/ z; @# P7 B可以通过函数变成灰度图7 y/ u4 M( C, c. u, H- D) E4 l
或者通过pixval查看具体值吧" @+ ~- b9 S+ c2 s' b6 V% `1 t" m
这个懂得不是很多
作者: lirui0081    时间: 2009-8-30 16:06
很不错的哟~!
作者: yzy364972    时间: 2009-8-30 17:08
如何把word里的数据导入excel呢
作者: handsome8848    时间: 2009-8-30 19:16
- `- ?3 i# n; ~. p
支持,导入数据我一般是用复制+赋值的~~6 s% t% f% Q! S$ N7 o8 P6 d
LZ的方法很好
作者: 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 6 g- g: ^3 {, V* c# V
: L8 w7 c4 W0 M
importdata也很强大
作者: 占领王    时间: 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
/ C6 {- v# a; 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的格式,不过就是有点麻烦" Y+ M# S1 O( J
另外xlsread 其实还是可以用,就是第一次导入数据的时候有点慢,个人觉得这个接口还是可以的,前提是机子好的话% j, r  O# s+ |
textread嘛,速度可以,但是因为我们本身就不常用,不大熟悉text,所以我不常用textread命令8 X: P/ i6 r1 }( v& z
我个人觉得fopen函数还是可以的,呵呵
作者: 大笨象    时间: 2009-12-7 12:34
一个很不错的帖子。
作者: shuaiyi    时间: 2009-12-7 12:36
呵呵……是得熟练最基本的操作。可以找本专业的书看看。
作者: 枫露之茗    时间: 2009-12-29 12:54
好东西,大家分享,精神可嘉  O" z4 i- R! q0 U; l
!!!!!!!!
作者: mnpfc    时间: 2010-1-5 14:39
谢谢分享!!!!!!!!!!!!!!!!!!!!!!!
作者: licoro    时间: 2010-1-7 15:22
回复 2# jyh123
% j( B& u/ D3 P3 C
/ O$ D& U+ w' [- q( W# u$ }1 S0 G: U9 J
    好呀!!!
作者: 彩虹天堂    时间: 2010-1-9 18:25
回复 1# xiaobingforever
2 B* n% c. H; K( h6 l; n7 J
% _: e: q6 [6 @8 C' H9 A% h: d/ V& K2 Y1 z
    好东西
作者: 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
竟然还有这用法
: _. T" \. ]* z2 A5 i+ E
作者: 鸣凤123    时间: 2015-8-14 20:15
楼主的帖子很不错,我觉得很有用4 L7 ?$ \# V3 u" `, S3 l3 y

作者: 421018735    时间: 2019-1-4 15:08
一点个人看法0 j1 T; R: W+ Z+ V: t0 D' }

作者: 2286773557    时间: 2020-2-12 14:02
对新手帮助蛮大的 谢谢楼主8 m( T7 V" u/ c





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