当前位置: 首页 > news >正文

MATLAB导出和导入Excel文件表格数据并处理

20250507

1.MATLAB使用table函数和writetable函数将数据导出Excel表格文件

我们以高斯函数为例子,高斯函数在数学和工程领域有着广泛的应用,它的一般形式为:

其中\mu是均值,决定了函数的中心位置;\sigma 是标准差,决定了函数的宽度。

函数名作用示例
table创建表格对象T = table(col1, col2, ...)
writetable将表格写入文件(Excel/CSV等)writetable(T, 'file.xlsx')
fullfile跨平台拼接文件路径fullfile('folder', 'file')
exist检查文件/文件夹是否存在exist('path', 'dir')
mkdir创建新文件夹mkdir('new_folder')
uigetdir交互式选择文件夹路径folder = uigetdir()

(1)创建表格:使用table函数将x和y数组组合成一个表格对象dataTable,并为两列数据指定列名Wavelength和Reflectivity。

(2)导出表格到 Excel:使用writetable函数将表格对象dataTable导出为名为SFBG_Reflectivity.xlsx的 Excel 文件。

clc
clear
close all
% 设置参数
mu = 0; % 均值
sigma = 1; % 标准差
% 生成x值
x = linspace(-5, 5, 1000);
% 计算对应的y值
y = gaussian(x, mu, sigma);
% 绘制高斯函数图像
figure;
plot(x, y, 'b', 'LineWidth', 2);
title(['高斯函数: \mu = ', num2str(mu), ', \sigma = ', num2str(sigma)]);
xlabel('x');
ylabel('f(x)');
grid on;
% 导出数据到Excel表格
dataTable = table(x',y','VariableNames',{'x值','y值'});
% 指定导出文件的路径
output_folder = 'C:\Users\53609\Desktop\Test\20250507_Test_data\导出数据';
% 确保输出文件夹存在,如果不存在则创建
if ~exist(output_folder,'dir')mkdir(output_folder); %创建文件夹
end
output_filename = fullfile(output_folder, '高斯函数据.xlsx'); % 创建完整的数据路径
% 保存为新的Excel文件
writetable(dataTable, output_filename);
disp('MATLAB导出完成')
% 定义高斯函数
function y = gaussian(x, mu, sigma)y = (1 / (sigma * sqrt(2 * pi))) * exp(-((x - mu).^2) / (2 * sigma^2));
end

运行代码后,会在当前工作目录下生成一个Excel文件,其中包含两列数据,第一列是x,第二列是y。

2、MATLAB实现readtable函数实现Excel表格数据的导入

函数名作用示例
readtable将 Excel 数据读取为表格data = readtable('data.xlsx', 'Sheet', 'Sheet1', 'Range', 'A1:D10');
xlsread读取数值和文本数据(旧版本)[num, txt] = xlsread('data.xlsx', 'Sheet1', 'A1:D10');
readmatrix读取数值矩阵matrix = readmatrix('data.xlsx', 'Sheet', 'Sheet1', 'Range', 'A1:D10');
readcell读取混合类型数据为单元格数组cell_data = readcell('data.xlsx', 'Sheet', 'Sheet1');
detectImportOptions检测并自定义导入选项opts = detectImportOptions('data.xlsx'); opts.SelectedVariableNames = {'A', 'C'}; data = readtable('data.xlsx', opts);

readtable 函数用于读取 Excel 文件中的数据,并将其存储在一个表格对象 excel_file 中。

filename {:, 1} 表示提取表格中第一列的数据,存储在 x变量中。

filename {:, 2} 表示提取表格中第二列的数据,存储在 y变量中。

plot(x,y, 'b') 用于绘制以 x为横坐标,y为纵坐标的折线图,其中 'b' 表示蓝色线。

title、xlabel 和 ylabel 函数分别用于设置图表的标题、横坐标标签和纵坐标标签。

grid on 用于显示网格线,使图表更清晰

clc
clear
close all
% 交互式表格数据读取与创建
input_folder = 'C:\Users\53609\Desktop\Test\20250507_Test_data\导出数据';
filename = fullfile(input_folder,'高斯函数据.xlsx');
% 检查文件是否存在
if exist(filename, 'file')data = readtable(filename, 'ReadVariableNames', false); % 假设无表头% 提取第一列数据first_column = data{:,1}; % 索引第一列% 提取第二列数据second_column = data{:, 2}; % 索引第二列disp('MATLAB导入完成')
end
x= first_column;
y = second_column;
figure;
plot(x, y, 'b', 'LineWidth', 2);
title(['高斯函数: \mu = ', num2str(mu), ', \sigma = ', num2str(sigma)]);
xlabel('x');
ylabel('f(x)');
grid on;

输出结果

相关文章:

  • nRF Connect SDK system off模式介绍
  • 【Hive入门】Hive增量数据导入:基于Sqoop的关系型数据库同步方案深度解析
  • React学习路线-Deepseek版
  • 如何应对客户在验收后提出新需求?
  • 【MCP】服务端搭建(python和uv环境搭建、nodejs安装、pycharma安装)
  • 多模态大语言模型arxiv论文略读(六十三)
  • 源码分析之Leaflet中的LayerGroup
  • 【AI提示词】双系统理论专家
  • Node.js面试题
  • 如何统一修改word中所有英文字母的字体格式
  • Java后端开发day43--IO流(三)--缓冲流转换流序列化流
  • ChromeDriverManager的具体用法
  • 鸿蒙开发Flex也可以用权重
  • Ceph集群OSD运维手册:基础操作与节点扩缩容实战
  • 认识中间件-以及两个简单的示例
  • Linux网络新手注意事项与配置指南
  • Qt开发:枚举的介绍和使用
  • eFish-SBC-RK3576工控板外部RTC测试操作指南
  • SpringBoot项目接入DeepSeek
  • Linux:web服务nginx
  • 聆听百年唐调正声:唐文治王蘧常吟诵传习的背后
  • 一热就出汗 VS 热死都不出汗的人,哪个更健康?
  • 习近平出席俄罗斯总统举行的欢迎仪式
  • 巴基斯坦信德省卡拉奇发生爆炸
  • 金融监管局:已设立74支私募股权投资基金,支持投资科技创新企业
  • 这个五月,有三部纪录电影值得一看