MATLAB 如何导入.txt文本

小试牛刀之MATLAB@MATLAB

MATLAB 如何导入.txt文本

1.fopen搭配textscan

2.利用impordata导入数据

3.采用load函数

在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

第一篇文章就这样吧!以后要继续加油噢!奥里给!
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_44246618/article/details/107484838