Matlab导入数据方法
最方便的方法:
一、MATLAB数据输入很简单:菜单-->FILE-->import data.搞定(可从excel ,txt中导入);
二、变量工作区有一个导入数据的按钮直接点击使用即可导入;
三、在工作区直接新建变量,然后用复制粘贴功能即可,新建变量进行编辑时就想excel一样简单操作。
还有三种方法,也是非常常用:
方法1:
将数据直接粘贴 .m 文件中或者粘贴到 .txt 中,放在当前工作目录下,用load 来调用,文件名就是变量名。
导 出时用,save命令,一种是临时保存二进制文件在工作区方便以后程序用,另一种需要一
asc文件倒出来,写文章那个用,方法如下: save 'b.txt' B -ascii %(把矩阵B的数据,导出到了TXT文件中,名字为b.txt),注意空格,-ascii 前有空格。
方法二:
先粘贴同一中,然后再 用dlmread函数来调用,A=dlmread('data.m') 。注意单引号。
方法三:
从cecel中直接导入用xlsread函数,eg: a=xlsread('yi.xlsx')。 同样注意 单引号。
导出时使用  xlswrite('a.xlsx',a) 即可。
PS:可以导入Char型
较为简单的方式,Matlab中可以这样写一下:
data=load('d:\');
t1=data(:,1);
y1=data(:,2);
t2=data(:,3);
y2=data(:,4);
plot(t1,y1,t2,y2,'r');
比较系统的描述如下:
1)打开文件
在读写文件之前,必须先用fopen函数打开或创建文件,并指定对该文件进行的操作方式。fopen函数的调用格式为:
fid=fopen(文件名,‘打开方式’)
说明:其中fid用于存储文件句柄值,如果返回的句柄值大于0,则说明文件打开成功。文件名用字符串形式,表示待打开的数据文件。常见的打开方式如下:
?
‘r’:只读方式打开文件(默认的方式),该文件必须已存在。
? ‘r+’:读写方式打开文件,打开后先读后写。该文件必须已存在。
? ‘w’:打开后写入数据。该文件已存在则更新;不存在则创建。
? ‘w+’:读写方式打开文件。先读后写。该文件已存在则更新;不存在则创建。
? ‘a’:在打开的文件末端添加数据。文件不存在则创建。
? ‘a+’:打开文件后,先读入数据再添加数据。文件不存在则创建。
另外,在这些字符串后添加一个“t”,如‘rt’或‘wt+’,则将该文件以文本方式打开;如果添加的是“b”,则以二进制格式打开,这也是fopen函数默认的打开方式。
2)关闭文件
文件在进行完读、写等操作后,应及时关闭,以免数据丢失。关闭文件用fclose函数,调用格式为:
sta=fclose(fid)
说明:该函数关闭fid所表示的文件。sta表示关闭文件操作的返回代码,若关闭成功,返回0,否则返回-1。如果要关闭所有已打开的文件用fclose(‘all’)。
2、二进制文件的读写操作
1)写二进制文件
fwrite函数按照指定的数据精度将矩阵中的元素写入到文件中。其调用格式为:
COUNT=fwrite(fid,A,precision)
说 明:其中COUNT返回所写的数据元素个数(可缺省),fid为文件句柄,A用来存放写入文件的数据,precision代表数据精度,常用的数据精度 有:char、uchar、int、long、float、double等。缺省数据精度为uchar,即无符号字符格式。
例6.8 将一个二进制矩阵存入磁盘文件中。
>> a=[1 2 3 4 5 6 7 8 9];
>> fid=fopen('d:\test.bin','wb') %以二进制数据写入方式打开文件
fid =
3 %其值大于0,表示打开成功
>> fwrite(fid,a,'double')
ans =
9 %表示写入了9个数据
>> fclose(fid)
ans =
0 %表示关闭成功
2)读二进制文件
fread函数可以读取二进制文件的数据,并将数据存入矩阵。其调用格式为:
[A,COUNT]=fread(fid,size,precision)
说 明:其中A是用于存放读取数据的矩阵、COUNT是返回所读取的数据元素个数、fid为文件句柄、size为可选项,若不选用则读取整个文件内容;若选用 则它的值可以是下列值:N(读取N个元素到一个列向量)、inf(读取整个文件)、[M,N](读数据到M×N的矩阵中,数据按列存放)。 precision用于控制所写数据的精度,其形式与fwrite函数相同。
3、文本文件的读写操作
1)读文本文件
fscanf函数可以读取文本文件的内容,并按指定格式存入矩阵。其调用格式为:
[A,COUNT]=fscanf(fid,format,size)
说 明:其中A用来存放读取的数据,COUNT返回所读取的数据元素个数,fid为文件句柄,format用来控制读取的数据格式,由%加上格式符组成,常见 的格式符有:d(整型)、f(浮点型)、s(字符串型)、c(字符型)等,在%与格式符之间还可以插入附加格式说
明符,如数据宽度说明等。size为可选 项,决定矩阵A中数据的排列形式,它可以取下列值:N(读取N个元素到一个列向量)、inf(读取整个文件)、[M,N](读数据到M×N的矩阵中,数据 按列存放)。
2)写文本文件
fprintf函数可以将数据按指定格式写入到文本文件中。其调用格式为:
fprintf(fid,format,A)
说明:fid为文件句柄,指定要写入数据的文件,format是用来控制所写数据格式的格式符,与fscanf函数相同,A是用来存放数据的矩阵。
例6.9 创建一个字符矩阵并存入磁盘,再读出赋值给另一个矩阵。
>> a='string';
>> fid=fopen('d:\','w');
>> fprintf(fid,'%s',a);
>> fclose(fid);
>> fid1=fopen('d:\','rt');
>> fid1=fopen('d:\','rt');
>> b=fscanf(fid1,'%s')
b =
string
matlab读txt文件
fid=fopen('fx.txt','r');
%得到文件号
[f,count]=fscanf(fid,'%f %f',[12,90]);
%把文件号1的数据读到f中。其中f是[12 90]的矩阵
%这里'%f %f'表示读取数据的形势,他是按原始数据型读出
fclose(fid);
%关闭文件
另外有的txt文件还可以用load来打开
其语句为
f=load('fx.txt)
我个人觉得用第一种方式较好。因为有些时候,特别是fx.txt 的一行种有多个数据时用load
就比较麻烦了。
另:转自百度空间的一个例程:hi.baidu/stonebraker/blog/item/dde674fae6fb051da9d31123.html
一 将excel数据导入
直接将下面三句话导入
[filename, pathname]= uigetfile('*.xls');    %寻源文件
file=[pathname filename];                    %赋名
x=xlsread(file);                            %格式转换为矩阵
之后就用x来代表导入的这个矩阵。
如excel 里输入了 1 2 3
                  4 5 6
如下命令
x(1,:)
ans =
      1      2      3
二 txe文件导入
假定名为 的文件中以下为文件内容
"
你好,我的数据
欢迎来到
fprintf格式动力学与控制技术论坛
www.dytrol
1 11 111 1111
2 22 222 2222
3 33 333 3333
4 44 444 4444
5 55 555 5555
"
这样的文件怎么读入数据呢?
方法有多种,现举两个比较简单实用的。
方法一:
在文件菜单中选择 file/import data,按照提示进行操作至结束。
在 command 窗口中输入
>> whos
Name            Size                    Bytes  Class
data            5x4                      160  double array
textdata        4x1                      300  cell array
Grand total is 54 elements using 460 bytes
>> data
data =
          1          11          111        1111
          2          22          222        2222
          3          33          333        3333
          4          44          444        4444
          5          55          555        5555
>> textdata
textdata =
    '你好'
    '欢迎来到'
    '动力学与控制技术论坛'
    'www.dytrol'
方法二:
[a1,a2,a3,a4]=textread('','%s%s%s%s','headerlines',4)
说明:%s可以是其他形式,跟读入的数据类型有关,比如这里也可以用%n,%f等。
这里%s的个数和[a1,a2,a3,a4]对应。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。