数学建模社区-数学中国

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

作者: xiaobingforever    时间: 2009-8-20 12:58
标题: Matlab数据导入之我见
Matlab功能真的很强大,数据接口做得也相当完美,和大家分享下自己文件读取方面的一些收获和体会吧。Matlab文件导入的函数很多,可以用doc命令打开帮助文档,在search栏里面输入?read查找,不过这样比较盲目,或者用help ?read,可以看到系统自带的文件特定格式的文件读取命令,常用的方法有+ z: M( O( }5 D% c! G% j$ j
xlsread,读取excel文件。( B* e9 k; @' I* h
textread,读取txt文件等等,还有很多,有兴趣的咱们可以一起去摸索。) z3 i! r% m1 C$ O; D% N/ W( u8 _
另外,R2007a左右的版本,系统可以自己生成文件读取函数,只要在默认Default窗口下查看当前目录下的Current Directory,好像是Directory,记得不大清啦,这台机子上没装Matlab,就是Workspace旁边的那个框选菜单,然后双击需要读取的文件(excel格式或txt格式都可以),会弹出一个对话框,在右下角位置上有一个Great m file 选框,选中即可,就会自动生成函数啦。
) U; F0 z4 b) u! t) s% v5 l另外,给大家分享下我自己用过的几个命令6 U" C4 q6 c4 ?: d' f
假设要读取的excel文件名为exmp.xls
. F5 c2 o- J  K9 }第一步,将文件放到当前文件夹里面;
  u3 ^1 U# L3 ?2 a& k4 ^+ q8 g, L第二步,写入命令
1 }: `; [4 W! R  @有很多种格式 num=xlsread('exmp.xls');/ t, L0 ?3 y/ u
num即读取的数值文件,好像以前的有些版本只能做到这一步,我用的是R2007a版本
1 |2 E& |0 x1 k他还支持其他命令,比如:[num,txt]=xlsread('exmp.xls','sheet1')
: p9 u! x, v4 e2 L; F1 anum返回工作表sheet1中数值格式的内容,不是数值格式的系统默认为NaN;
+ i9 t3 O  y! M7 f' f* I7 @  p$ i& @txt返回sheet1中字符串格式的内容,以元胞的形式存储到变量txt中,同理,不是字符串格式的默认为NaN;, |7 G. S! P5 G; j
这样大家就很方便的进行数据写入啦。其中sheet1可以任意改为exmp内的工作表,比如'sheet2'或者你自己重命名的工作表。2 ~$ U; g& v( [; h3 d
还有更高的
7 R9 k$ u8 Z7 b: K! P[num,txt]=xlsread('exmp.xls','sheet1','A1:F81')
! Q2 d  |) D: V5 S5 X; s6 G/ Anum返回A1到F81矩形框中数值格式的内容: v  u; Z- Q/ E0 u* t
txt返回A1到F81矩形框中字符串格式的内容
3 p, t9 R( b  {  m当然矩形框大家可以根据实际需要任意定义
) R! }* k5 Q' D: c7 \; Z这样是不是很方便呀/ M/ Y9 O! q6 P2 Y5 E7 t. Z
还有
' p& E& I. E% ]  \9 E[num,txt,all]=xlsread('exmp.xls','sheet1')/ y, U( L  F7 |% b5 K
all返回的是工作表sheet1中的全部内容,不过全部以元胞形式存储在all中  Q$ A/ L3 y/ F) u; A5 R, I; y
真想全部掌握excel文件读取功能可以用doc xlsread 命令查看帮助文档,里面讲得很详细4 G  S& Y  M0 W$ P$ Z; M
以前还挺喜欢用这几个命令的
  F6 L" c5 B* ^: R$ H% |# ]后来发现他有个很大的缺点,就是速度太慢,读取大的数据量时需要好几秒钟
' K: K, Q  E+ `建议大家将数据导入txt中,用命令textread('exmp.txt'),速度会更快
% _" L. Y% Y5 A" e1 S" s或者用fopen函数,这个可能就会麻烦一点& W* |' X6 p) j# l0 L, r8 w( P) n8 v
只是自己的一些拙见,相互学习嘛
) Y1 Q, x$ n0 I: w* ?7 E% T# S错误的地方请大家指正,抛砖引玉就达到效果啦
作者: 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
我正要找呢,呵呵,谢谢啦~~
( ~8 h2 w! x. O* o3 v+ m顺便请教一下,如何把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
好帖,谢谢!( W6 A& U0 x  R" {. q) |6 j% G
请问关于图像文件的读取有没有什么比较好用的方法?
作者: 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 - @: B6 s) o% J
所有数据导入好像用importdata可行7 ~- F4 E  C. U
返回一个结构体变量. r0 e! e/ ?! L, l
每一个工作表是一个域 也可以分文本域数值2 v- t; E7 m/ P' y$ ~3 H
具体请参考
) y) _2 |7 x7 o8 fhttp://www.madio.cn/mcm/thread-31214-1-1.html
作者: xiaobingforever    时间: 2009-8-30 13:58
24# sisi_bupt
7 s9 v! B/ K, }这个就不好说啦
3 y1 ^' ^3 o$ v6 v% o英爱应该数MATLAB图像处理的内容
6 E( i) l0 O" E. c- M5 y. s9 w一般是用imread吧8 f) \( ]/ l/ O1 W7 E
生成一个3维int8类型的数组
4 w4 T+ u4 \, z2 k+ |- E5 \2 ^每一个像素点对应一个坐标值
% U* E# [- K" b! I可以通过函数变成灰度图2 T* t5 o" a! |. [3 U4 ^
或者通过pixval查看具体值吧# A; B7 ?0 s! u: S
这个懂得不是很多
作者: lirui0081    时间: 2009-8-30 16:06
很不错的哟~!
作者: yzy364972    时间: 2009-8-30 17:08
如何把word里的数据导入excel呢
作者: handsome8848    时间: 2009-8-30 19:16
0 z, y1 _* [( g
支持,导入数据我一般是用复制+赋值的~~
, s* O  w% S- q- X5 aLZ的方法很好
作者: 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
" G0 j& {2 G) @% ?, Y* `9 ]6 h- D% d' A) A  c& ^) X% d
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   X/ G5 k5 u. Y! f
很好呀!谢谢楼主!
作者: 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的格式,不过就是有点麻烦
. Z/ A$ C% d8 u. u/ @另外xlsread 其实还是可以用,就是第一次导入数据的时候有点慢,个人觉得这个接口还是可以的,前提是机子好的话: r, y; V3 A9 N! i1 i: m
textread嘛,速度可以,但是因为我们本身就不常用,不大熟悉text,所以我不常用textread命令& x# \8 x$ K4 W- @/ [8 }& U
我个人觉得fopen函数还是可以的,呵呵
作者: 大笨象    时间: 2009-12-7 12:34
一个很不错的帖子。
作者: shuaiyi    时间: 2009-12-7 12:36
呵呵……是得熟练最基本的操作。可以找本专业的书看看。
作者: 枫露之茗    时间: 2009-12-29 12:54
好东西,大家分享,精神可嘉
; d; d4 U5 o) @8 H!!!!!!!!
作者: mnpfc    时间: 2010-1-5 14:39
谢谢分享!!!!!!!!!!!!!!!!!!!!!!!
作者: licoro    时间: 2010-1-7 15:22
回复 2# jyh123 7 K1 l0 t/ v. T) P: I9 s

4 w3 K% N# `1 Z6 z. h# }% m; q, Q: E1 c! I4 N) a
    好呀!!!
作者: 彩虹天堂    时间: 2010-1-9 18:25
回复 1# xiaobingforever
- k+ |/ P* ~9 l& R8 R( e* `
: |! P- {' v- G8 V5 M
! I* K2 g3 Y( A8 {1 b9 Z+ q    好东西
作者: 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
竟然还有这用法, @( ~- Q$ E: _  G$ S' T

作者: 鸣凤123    时间: 2015-8-14 20:15
楼主的帖子很不错,我觉得很有用. M9 B7 |* S& {9 T' R" U/ d

作者: 421018735    时间: 2019-1-4 15:08
一点个人看法0 p, ]$ T: v% ^

作者: 2286773557    时间: 2020-2-12 14:02
对新手帮助蛮大的 谢谢楼主
4 O' g! n& J3 k$ O




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