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

20250507

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

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

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

|------------|---------------------|----------------------------|
| 函数名 | 作用 | 示例 |
| 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;

输出结果

相关推荐
前端拿破轮1 分钟前
🤡🤡🤡面试官:就你这还每天刷leetcode?连四数相加和四数之和都分不清!
算法·leetcode·面试
VXHAruanjian88814 分钟前
CosyVoice2.0整合包:免费一键启动,释放语音克隆的创意潜能
人工智能
慕婉030724 分钟前
Tensor自动微分
人工智能·pytorch·python
北辰alk26 分钟前
RAG中的文档解析:从原始文档到高效索引的完整流程
人工智能
地平线开发者26 分钟前
征程 6|工具链量化简介与代码实操
算法·自动驾驶
DoraBigHead32 分钟前
🧠 小哆啦解题记——谁偷改了狗狗的台词?
算法
Kaltistss33 分钟前
240.搜索二维矩阵Ⅱ
线性代数·算法·矩阵
轻语呢喃38 分钟前
每日LeetCode:合并两个有序数组
javascript·算法
不会计算机的g_c__b44 分钟前
跨越NLP的三重曲线:从词法到叙事的进化之路
人工智能·自然语言处理
Baihai_IDP1 小时前
AI 深度研究(Deep Research)原理解析
人工智能·程序员