MATLAB数据文件读写:2.矩阵数据读取

矩阵数据读取

写入文件--save函数

保存变量到文件中,用于以后使用。

save(fielname)

  • 将当前工作区中所有变量保存到matlab格式的二进制文件filename中。: .mat

save(filename, 'var',fmt)

  • 将当前工作区中var指定的结构体数组的变量或字段保存到matlab格式的二进制文件(.mat)filename中。
  • fmt指定保存的格式,可以是'ascii'、'binary'、'base64'、'table'中的一个。

save(filename, 'var','-append')

  • 将新变量添加到一个现有文件中
  • 如果mat文件中已经存在了变量var,则会覆盖原有变量。

例子:

matlab 复制代码
save('data.mat','x','binary')
% 保存变量x到文件data.mat中,以二进制格式保存

save('data.mat')
% 保存当前工作区的所有变量到文件data.mat中

save('data.mat','x','-append')
% 将变量x追加到文件data.mat中

% 例如
x = [1 2 3; 4 5 6];
b = struct('name','Alice','age',25);
c=pi;
save('data.mat')
clear
load('data.mat')
% 加载文件data.mat中的变量

读取文件--load函数

与save函数相对应,通常与save搭配使用;

load(filename)

  • 从filename加载数据;
  • 如果filename是MAT文件,将mat文件中的变量加载的MATLAB工作区;
  • 如果filename是ASCI,将会创建一个包含该文件数据的双精度矩阵;

load(filename,'var')

  • 加载MAT文件中的指定变量

load(filename,'a*')

  • 加载MAT文件中所有以a开头的变量 ,*表示使用通配符;
    load(filename,'-regexp',expl,exp2...expn)
  • 只加载名称与正则表达式匹配 的变量或字段,指定为字符向量或字符串。
    例如:

load('filename.mat','-regexp','^Mon','^Tues')

  • 仅加载文件中名称以Mon或Tues开头的变量。

矩阵数据读写一writematrix与readmatrix函数

writematrix(A)

  • 同构数组A 写入以逗号分隔的文本文件
  • 文件名为数组的工作区变量名称,附加扩展名.txt;
  • 如果writematrix无法根据数组名称构造文件名,那么它会写入matrix.txt文件中;
  • A中每个变量的每一列将成为输出文件中的列。writematriⅸ函数会覆盖现有文件。

writematrix(A,filename)

  • 写入具有filename指定 的名称和扩展名的文件。
    扩展名必须是下列格式之一:
    .txt、.dat或.csv(适用于带分隔符的文本文件);
    .xls、.xlsm或,.xlsx(适用于ExcelE电子表格文件);

例子:

matlab 复制代码
a=rand(10);
writematrix(a);
% 写入文件a.txt中
writematrix(a,'b.xls');

writematrix(__,Name,Value)

  • 在包括上述语法中任意输入参数的同时,还可通过一个或多个Name,Value对组参数指定其他选项来将数组写入文件中。
  • 例如,指定分隔符制表符 (默认为逗号):
    writematrix(M,'M_tab.txt','Delimiter','tab')

A=readmatrix(filename)

  • 通过从文件中读取列向数据来创建数组。readmatrix函数可自动检测文件的导入参数。
  • readmatrix基于文件的扩展名确定文件格式
    .txt、.dat或.csv(适用于带分隔符的文本文件)
    .xls、.xlsb、.xlsm、.xlsx、.xltm、.xtx或.ods(适用于电子表格文件)
  • 对于包含数值和文本混合数据的文件,默认情况下,readmatrix将数据作为数值数组导入。

A=readmatrix(filename,opts)

  • 使用导入选项opts(详情参见help文件)

例子:

matlab 复制代码
a=readmatrix('a.txt');
b=readmatrix('b.xls');

表格数据读写一writetable与readtable函数

writetable(T,filename)

  • 写入具有filename指定的名称和扩展名的文件;

T=readtable(filename)

  • 通过从文件中读取列向数据来创建表。

写入excel:xlswrite

读取excel:xlsread

最新的MATLAB不推荐使用这两个函数;

另外还有针对元胞数据读写的:

writecell

readcell

矩阵数据读入一importdata函数

A=importdata(filename)

  • 将数据加载到数组A中;

A=importdata(filename,delimiterIn)

  • 将delimiterIn解释为ASCI文件filename中的列分隔符;

A=importdata(filename,delimiterIn,headerlinesIn)

  • 从ASCI文件filename中,以dilimiterIn为分隔符,从headerlinesIn+l行开始读取;

例子:

matlab 复制代码
A=importdata('data.txt');

b=A.data;
a.data;
相关推荐
敖云岚29 分钟前
【Redis】分布式锁的介绍与演进之路
数据库·redis·分布式
LUCIAZZZ1 小时前
HikariCP数据库连接池原理解析
java·jvm·数据库·spring·springboot·线程池·连接池
我在北京coding1 小时前
300道GaussDB(WMS)题目及答案。
数据库·gaussdb
小Tomkk1 小时前
阿里云 RDS mysql 5.7 怎么 添加白名单 并链接数据库
数据库·mysql·阿里云
明月醉窗台2 小时前
qt使用笔记二:main.cpp详解
数据库·笔记·qt
沉到海底去吧Go3 小时前
【图片自动识别改名】识别图片中的文字并批量改名的工具,根据文字对图片批量改名,基于QT和腾讯OCR识别的实现方案
数据库·qt·ocr·图片识别自动改名·图片区域识别改名·pdf识别改名
老纪的技术唠嗑局3 小时前
重剑无锋,大巧不工 —— OceanBase 中的 Nest Loop Join 使用技巧分享
数据库·sql
未来之窗软件服务4 小时前
JAVASCRIPT 前端数据库-V6--仙盟数据库架构-—-—仙盟创梦IDE
数据库·数据库架构·仙盟创梦ide·东方仙盟·东方仙盟数据库
科研工作站5 小时前
【创新算法】改进深度优先搜索算法配合二进制粒子群的配电网故障恢复重构研究
matlab·配电网·故障恢复·改进粒子群·深度优先搜索·33节点
一只爱撸猫的程序猿5 小时前
构建一个简单的智能文档问答系统实例
数据库·spring boot·aigc