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

发布于:2025-05-07 ⋅ 阅读:(16) ⋅ 点赞:(0)

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;

输出结果


网站公告

今日签到

点亮在社区的每一天
去签到