导航:首页 > 程序命令 > matlab导入数据命令

matlab导入数据命令

发布时间:2023-02-11 20:09:29

❶ matlab导入dxf数据

MATLAB 如何导入.txt文本
在matlab GUI的学习中,需要导入各种格式的.txt文件,心血来潮想总结一波。
首先,利用uigetfile选择文件位置,代码命令如下:

[filename, pathname] = uigetfile({'*.xls;';'*.txt';'*.xlsx;'; }, '导入数据',...
'MultiSelect','off'); % 不允许同时选择多个文件
if isequal(filename,0)
disp('User selected Cancel')
else
disp(['User selected', fullfile(pathname, filename)]) %当返回了一个文件的时候,可以用fullfile将路径和文件名组合起来
end
登录后复制
在此列举一种比较复杂的情况,有中文表头的数据文件(在此列举滚动轴承的信号数据,数据量比较大):

MATLAB 导入.txt文本的几种方式:
1.fopen搭配textscan
file=fullfile(pathname, filename); % 导入.txt文件
f=fopen(file); %以只读模式打开混合格式文本文件
dt=textscan(f,'%s'); %采用textscan 读取数据
登录后复制
对于数据量大的文本文件推荐使用textscan,不推荐使用textread函数读取数据。
在此种情况下,导入的数据格式如下:

可以自行调整得到文本及数据。代码如下(可能不甚高明,欢迎小伙伴指教):
因为涉及到cell型数据向double类型的数据转换,略有一丢丢麻烦。
FaultLayer=dt{1,1}(1:f);
A=transpose(str2num(char(dt{1,1}(f+1:end))));
for ilength=1:(length(dt{1,1})/f-1)
data(ilength,1:4)=A((ilength-1)*f+1:ilength*f);
end
登录后复制
得到结果如下:
2.利用impordata导入数据
datatable = importdata(file); %加载txt数据(只导入数据)
data = datatable.data; %读取非元胞的数据
登录后复制
此代码只导入数据,格式与.txt文本文件相同,与上一方法经过转换后得到的格式相同,如下图所示,对于只导入数据的文本文件十分简便。
3.采用load函数
貌似只能导入数据文件,这个不是十分清楚。

file=fullfile(pathname, filename); % 导入.txt文件
num=load(file) ;
[m,n]=size(num);
登录后复制
导入的数据如下图所示:

最后提醒一点,当导入.txt文本时,中文出现乱码时,在前面添加以下代码即可解决。
feature('DefaultCharacterSet', 'UTF8'); % 使得matlab支持utf-8编码
登录后复制
另外,我之前编写GUI代码的时候,对于可以导入.txt和.xls的多种文件格式的处理感到十分疑惑,具体的数据处理并不相同,如何才能区别导入的是何种文件呢?最后我瞎搞,弄了一个复杂的方法解决,希望有小伙伴告诉我怎么解决(期待.jpg)

if isempty(findstr(filename,'.txt'))==0 % 为空,结果为1
feature('DefaultCharacterSet', 'UTF8'); % 使得matlab支持utf-8编码
file=fullfile(pathname, filename); % 导入.txt文件
f=fopen(file); %以只读模式打开混合格式文本文件,列数
dt=textscan(f,'%s'); %采用textscan 读取数据
FaultLayer=dt{1,1}(1:f);
A=transpose(str2num(char(dt{1,1}(f+1:end))));
for ilength=1:(length(dt{1,1})/f-1)
data(ilength,1:4)=A((ilength-1)*f+1:ilength*f);
end
flag_load=true;
else
if (isempty(findstr(filename,'.xlsx'))==0||isempty(findstr(filename,'.xls'))==0 )
[num,txt,raw] = xlsread(filename,-1); %导入.xlsx文件 或.xls文件
[m,n]=size(num);
flag_load=true;
else
string=strcat(pathname,filename);
errordlg(string+"读取失败,请检查文件格式!",'错误提示');
end
end
登录后复制

阅读全文

与matlab导入数据命令相关的资料

热点内容
如何下载千东商城app 浏览:962
pbe加密教学视频 浏览:101
微信如何接收app信息有声音 浏览:530
redis入门指南pdf 浏览:597
程序员粒子效应 浏览:854
任意门app如何取消订单 浏览:619
嘀嗒加密呼叫是什么意思 浏览:825
null是编译期常量吗 浏览:33
袋鼠跳跳app怎么玩 浏览:697
python强制删除非空文件夹 浏览:311
pdf转word后如何排版 浏览:422
第七感pdf 浏览:115
pythonfor双循环 浏览:260
华为手机如何找到电脑的文件夹 浏览:962
程序员感觉疲惫 浏览:481
php清空清空cookies 浏览:25
触漫直播申请的内部app在哪里 浏览:245
如何卡崩高级服务器生存 浏览:650
华为手机云电脑app在哪里 浏览:31
linux文件夹大小限制 浏览:67