学习笔记3

一、提取.mat里面的数据方法

1)importdata函数,然后赋值变量,注意这时候是列向量,如果要用writetabel函数则需要转置一下,如下:

%转成excel格式
filename1='D:\360MoveData\Users\Kim\Desktop\第2组操稳性实验数据\转向轻便性2\方向盘转角\真依维柯换悬架轻便性3#18hzfxlpWave.mat';
A=importdata(filename1);
t1=A.a0;
t1=t1';
angel=A.a1;
angel=angel';
filename2='D:\360MoveData\Users\Kim\Desktop\第2组操稳性实验数据\转向轻便性2\方向盘转矩\真依维柯换悬架轻便性3#16hznjlpWave.mat';
B=importdata(filename2);
t2=B.a0;
t2=t2';
Me=B.a1;
Me=Me';
T = table(t1,angel,t2,Me)
filename3='D:\360MoveData\Users\Kim\Desktop\操稳性试验数据.xlsx'
writetable(T,filename3)

2)xlsread函数读取excel,但是有时候不好用,最好用1)or 3)办法

3)保存matlab如下importfile函数,使用时调用即可。

function importfile(filename)
%IMPORTFILE(FILETOREAD1)
%  从指定文件中导入数据
%  FILETOREAD1:  要读取的文件
% 导入文件
newData1 = load('-mat', filename);%加载变量名,形成结构数组newData1 
% 在基础工作区中从这些字段创建新变量。
vars = fieldnames(newData1);%将结构数组newData1中的变量名返回形成一个元胞数组vars 
for i = 1:length(vars)
    assignin('base', vars{i}, newData1.(vars{i}));
end

函数解析如下:

filename = 'D:\360MoveData\Users\Kim\Desktop\第2组操稳性实验数据\蛇形2\侧倾角\蛇行30kmh.mat';
newData1 = load('-mat', filename);%load(filename,"-mat",variables) 加载 filename 中的指定变量variables。
% 在基础工作区中从这些字段创建新变量。
vars = fieldnames(newData1);%返回一个newData1中的变量名组成的元胞数组,好像返回的是列数组
for i = 1:length(vars)
    assignin('base', vars{i}, newData1.(vars{i}));%vars{1}返回的是'a0'
    %assignin(ws,var,val) 将值 val 赋给工作区 ws 中的变量 var。
    %%例如assignin('base','x',42) 将值 42 赋予 MATLAB® 基础工作区中的变量 x。
end
%命令行窗口查看相关数据结构
newData1
vars
length(vars)
vars{1}%元胞数组索引出变量名
newData1.(vars{1});%结构数组所以出变量名对应的数据,形成一个列向量,这个和newData1.a0的效果是一样的

这个函数并非无用功,importdata的法1)和利用assignin重新将将数值赋值给工作区中的变量的法3),后者可以直接调用工作区里的变量了。二者区别可以在工作区看出:

二:元胞数组和结构体数组

a=cell(2,3); %定义一个两行三列的元胞数组

b={[1],rand(3);'sadasda',rand(1,2)} %定义并且初始化一个两行两列的元胞数组

%X = rand(n) 返回一个由均匀分布的随机数组成的 n×n 矩阵。

c=b{1,2} %提取元胞数组中的具体元素

d=b(1,:) %结果还是元胞数组,提取第一行

元胞数组创建用cell()或者{} ,元胞数组的索引用的是()or {},前者返回的仍然是cell类型,是1×1 cell类型;而后者返回的是是对应元素的具体值。

最简单的结构体数组创建用结构体数组名字加.创建。

S(1,1).x = linspace(0,2*pi);
S(1,1).y = sin(S(1,1).x);
S(1,1).title = 'y = sin(x)';
S(2,1).x = linspace(0,2*pi);
S(2,1).y = cos(S(2,1).x);
S(2,1).title = 'y = cos(x)';
S
a=S(1,1)

结构数组形象结构——图源b站

  • 16
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值