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

Matlab基础篇:数据输入输出

前言

数据输入和输出是 Matlab 数据分析和处理的核心部分。良好的数据输入输出能够提高工作效率,并确保数据处理的准确性。本文将详细介绍 Matlab 数据输入输出的各种方法,包括导入和导出数据、数据处理和数据可视化。

一、导入数据

Matlab 提供了多种方法导入外部数据文件,包括文本文件、Excel 表格、数据库等。以下是几种常用的导入数据方法。

  1. 导入文本文件
    • 使用 load 函数导入简单的文本文件:

    data = load('data.txt');  % 导入 txt 文件

  • 使用 fscanf 和 fgets 函数读取特定格式的文本文件:

    fid = fopen('data.txt', 'r');  % 打开文件data = fscanf(fid, '%f');      % 逐行读取数据fclose(fid);                   % 关闭文件

  1. 导入 CSV 文件
    • 使用 csvread 函数导入 CSV 文件:

    csv_data = csvread('data.csv');  % 读取 CSV 文件

  • 使用 readtable 函数导入 CSV 文件,并将数据存储在一个表中,便于后续处理:

    table_data = readtable('data.csv');  % 读取 CSV 文件到表

  1. 导入 Excel 文件
    • 使用 xlsread 函数导入 Excel 文件:

    [num, txt, raw] = xlsread('data.xlsx');  % 读取 Excel 文件

  • 使用 readmatrix 和 readcell 函数导入 Excel 文件:

    matrix_data = readmatrix('data.xlsx');  % 读取 Excel 文件中的数值数据cell_data = readcell('data.xlsx');  % 读取 Excel 文件中的所有数据

  1. 从数据库导入数据
    • 通过 database 函数连接到数据库,并使用 SQL 查询语句进行数据导入:

    conn = database('database_name', 'username', 'password');  % 连接到数据库curs = exec(conn, 'SELECT * FROM table_name');  % 执行 SQL 查询curs = fetch(curs);  % 获取查询结果db_data = curs.Data;  % 保存数据close(conn);  % 关闭数据库连接

以下是几种常用的导入数据方法总结:

导入方法函数示例说明
文本文件loaddata = load('data.txt');适用于简单数字文本文件
文本文件fscanffgetsfscanf(fid, '%f');适用于特定格式的文本文件
CSV 文件csvreadcsv_data = csvread('data.csv');导入 CSV 文件
CSV 文件readtabletable_data = readtable('data.csv');导入 CSV 文件到表
Excel 文件xlsread[num, txt, raw] = xlsread('data.xlsx');导入 Excel 文件
Excel 文件readmatrixreadcellmatrix_data = readmatrix('data.xlsx');导入 Excel 文件中的数据
数据库databaseexecfetchconn = database(...); curs = exec(...);从数据库导入数据

二、导出数据

在数据处理和分析完毕之后,常常需要将结果导出到文件中保存或与他人共享。Matlab 提供了多种导出数据的方法。

  1. 导出到文本文件
    • 使用 save 函数导出变量到 .mat 文件(Matlab 专用格式):

    save('result.mat', 'data');  % 将变量 data 保存到 result.mat 文件

  • 使用 fprintf 函数导出数据到文本文件:

    fid = fopen('result.txt', 'w');  % 打开文件fprintf(fid, '%.2f\n', data);    % 将数据写入文件fclose(fid);                     % 关闭文件

  1. 导出到 CSV 文件
    • 使用 csvwrite 函数将数据导出到 CSV 文件:

    csvwrite('result.csv', data);  % 将数据保存到 CSV 文件

  • 使用 writetable 函数将表格导出到 CSV 文件:

    writetable(table_data, 'result.csv');  % 将表格数据保存到 CSV 文件

  1. 导出到 Excel 文件
    • 使用 xlswrite 函数将数据导出到 Excel 文件:

    xlswrite('result.xlsx', data);  % 将数据保存到 Excel 文件

  • 使用 writematrix 和 writecell 函数将数据导出到 Excel 文件:

    writematrix(matrix_data, 'result.xlsx');  % 将矩阵数据保存到 Excel 文件writecell(cell_data, 'result.xlsx');  % 将元胞数据保存到 Excel 文件

以下是几种常用的导出数据方法总结:

导出方法函数示例说明
文本文件savesave('result.mat', 'data');保存到 Matlab 专用格式
文本文件fprintffprintf(fid, '%.2f\n', data);导出到文本文件
CSV 文件csvwritecsvwrite('result.csv', data);保存到 CSV 文件
CSV 文件writetablewritetable(table_data, 'result.csv');将表格保存到 CSV 文件
Excel 文件xlswritexlswrite('result.xlsx', data);保存到 Excel 文件
Excel 文件writematrixwritecellwritematrix(data, 'result.xlsx');将矩阵或元胞保存到 Excel 文件

三、数据处理

在数据导入之后,我们常常需要对数据进行一些处理,如排序、筛选、统计和清理。

  1. 数据排序
    • 使用 sort 函数对数组或矩阵进行排序:

    sorted_data = sort(data);  % 对数组进行排序sorted_matrix = sortrows(matrix_data);  % 对矩阵的行进行排序

  1. 数据筛选
    • 使用逻辑索引对数据进行筛选:

    filtered_data = data(data > 10);  % 筛选出大于 10 的数据

  1. 数据统计
    • 使用 Matlab 提供的统计函数对数据进行统计分析:

    mean_data = mean(data);      % 计算平均值std_data = std(data);        % 计算标准差median_data = median(data);  % 计算中位数

  1. 数据清理
    • 使用 isnan 和 fillmissing 函数对缺失数据进行标记和处理:

    data_with_nan = [1, 2, NaN, 4];idx_nan = isnan(data_with_nan);  % 标记缺失数据data_filled = fillmissing(data_with_nan, 'linear');  % 使用线性插值填补缺失数据

以下是常见数据处理方法的总结:

数据处理方法函数示例说明
数据排序sortsortrowssorted_data = sort(data);对数组或矩阵进行排序
数据筛选逻辑索引filtered_data = data(data > 10);筛选出特定条件的数据
数据统计meanstdmedianmean_data = mean(data);计算平均值、中位数、标准差
数据清理isnanfillmissingdata_filled = fillmissing(data_with_nan, 'linear');处理缺失数据

四、数据可视化

数据处理完毕之后,我们可以通过数据可视化来更直观地展示数据。Matlab 提供了丰富的数据可视化工具,能够绘制各种类型的图形,用于数据分析和展示。

  1. 绘制基本图形
    • 二维线图:使用 plot 函数绘制基本的二维线图。

        x = 0:0.1:10;y = sin(x);plot(x, y);  % 绘制二维线图title('Sine Wave');xlabel('x');ylabel('sin(x)');grid on;  % 打开网格

  • 散点图:使用 scatter 函数绘制二维散点图。

        x = randn(100, 1);y = randn(100, 1);scatter(x, y, 'filled');title('Scatter Plot');xlabel('x');ylabel('y');grid on;

  • 柱状图:使用 bar 函数绘制柱状图。

        categories = {'A', 'B', 'C', 'D', 'E'};values = [10, 20, 30, 25, 15];bar(categorical(categories), values);title('Bar Graph');xlabel('Category');ylabel('Values');

  1. 绘制高级图形
    • 箱线图:使用 boxplot 函数绘制箱线图,用于显示数据分布和异常值。

        data = randn(100, 5);boxplot(data);title('Box Plot');xlabel('Category');ylabel('Values');

  • 热图:使用 heatmap 函数绘制热图,主要用于展示矩阵数据的大小和分布。

        data = rand(10, 10);heatmap(data);title('Heatmap');

  • 三维表面图:使用 surf 函数绘制三维表面图。

        [X, Y] = meshgrid(-3:0.1:3, -3:0.1:3);Z = sin(sqrt(X.^2 + Y.^2));surf(X, Y, Z);title('Surface Plot');xlabel('X');ylabel('Y');zlabel('Z');grid on;

下表总结了一些常用的绘图函数及其示例:

图形类型函数示例说明
二维线图plotplot(x, y);绘制二维线图
散点图scatterscatter(x, y, 'filled');绘制二维散点图
柱状图barbar(categorical(cat), values);绘制柱状图
箱线图boxplotboxplot(data);绘制箱线图
热图heatmapheatmap(data);绘制热图
三维表面图surfsurf(X, Y, Z);绘制三维表面图

  1. 数据绘图示例
    下面通过一个综合示例,展示如何进行数据读取、处理、绘图的全过程。

示例:从 CSV 文件中导入数据,进行简单的数据处理,并绘制几种图形展示结果。

假设有一个 CSV 文件 data.csv,内容如下:

ID,Value1,Value2
1,10,100
2,15,110
3,20,105
4,25,95
5,30,120

  1. 导入数据

    % 导入数据到表格data = readtable('data.csv');

  1. 数据处理

    % 计算 Value1 和 Value2 的平均值mean_val1 = mean(data.Value1);mean_val2 = mean(data.Value2);% 筛选出 Value1 大于 20 的数据filtered_data = data(data.Value1 > 20, :);

  1. 数据可视化

    % 绘制折线图figure;subplot(2, 2, 1);plot(data.ID, data.Value1, '-o', 'DisplayName', 'Value1');hold on;plot(data.ID, data.Value2, '-s', 'DisplayName', 'Value2');title('Line Plot of Values');xlabel('ID');ylabel('Values');legend('show');grid on;% 绘制散点图subplot(2, 2, 2);scatter(data.Value1, data.Value2, 'filled');title('Scatter Plot of Value1 vs Value2');xlabel('Value1');ylabel('Value2');grid on;% 绘制柱状图subplot(2, 2, 3);bar(categorical(data.ID), [data.Value1, data.Value2]);title('Bar Graph of Values');xlabel('ID');ylabel('Values');legend({'Value1', 'Value2'});grid on;% 绘制箱线图subplot(2, 2, 4);boxplot([data.Value1, data.Value2], {'Value1', 'Value2'});title('Box Plot of Values');ylabel('Values');

通过此综合示例,我们从 CSV 文件中导入数据,进行了简单的数据处理,并绘制了折线图、散点图、柱状图和箱线图,用于展示和分析数据。

五、总结

本文详细介绍了 Matlab 的数据输入输出功能,包括如何导入和导出文本文件、CSV 文件、Excel 文件以及数据库中的数据。同时,通过数据处理方法,如数据排序、筛选、统计和清理,对导入的数据进行了处理。最后,介绍了数据可视化工具,通过各种图形展示数据处理结果。

相关文章:

Matlab基础篇:数据输入输出

前言 数据输入和输出是 Matlab 数据分析和处理的核心部分。良好的数据输入输出能够提高工作效率,并确保数据处理的准确性。本文将详细介绍 Matlab 数据输入输出的各种方法,包括导入和导出数据、数据处理和数据可视化。 一、导入数据 Matlab 提供了多种方…...

MySQL字典数据库设计与实现 ---项目实战

软件准备✍:Mysql与Navicat可视化命令大全 ----项目实战 文章前言部分 目录 一.摘要 二.设计内容 三.项目实现 一.摘要 本项目关注于字典数据库表结构的设计和数据管理。通过现有的sql文件,实现system_dict_type和system_dict_data两个数据表。随后…...

python数据分析——数据预处理

数据预处理 前言一、查看数据数据表的基本信息查看info()示例 查看数据表的大小shape()示例 数据格式的查看type()dtype()dtypes()示例一示例二 查看具体的数据分布describe()示例 二…...

【Python】使用matplotlib绘制图形(曲线图、条形图、饼图等)

文章目录 一、什么是matplotlib二、matplotlib 支持的图形三、如何使用matplotlib1. 安装matplotlib2. 导入matplotlib.pyplot3. 准备数据4. 绘制图形5. 定制图形6. 显示或保存图形7. (可选)使用subplots创建多个子图注意事项: 四、常见图形使…...

vue下载本地xls模版静态文件

需求导入的下载模版不想放在服务器放在前端本地下载静态资源最简单的方式直接访问 public 文件夹下的文件 方法一:使用静态文件路径 将文件放在 public 文件夹中: 把你的文件从 src/assets 移动到 public 文件夹。例如:public/template.xls。…...

手机开热点,里面的WPA2-Personal和WPA3-Personal的区别

WPA2-Personal和WPA3-Personal这两种协议都是用来保护无线网络安全的,但它们在加密强度和安全性方面有所不同。 WPA2-Personal (Wi-Fi Protected Access 2) WPA2是目前最广泛使用的Wi-Fi安全标准之一。它使用AES(Advanced Encryption Standard&#xf…...

算法课程笔记——点积叉积

算法课程笔记——点积叉积...

详解 | DigiCert EV代码签名证书

简介 DigiCert EV 代码签名证书是一种高级别的代码签名证书,它不仅提供了标准代码签名证书的所有安全特性,还增加了额外的身份验证流程,以确保软件开发者或发布者的身份得到最严格验证。这对于提升软件的信任度、防止恶意篡改和确保下载安全…...

pdf压缩大小,PDF压缩大小不影响清晰度

你是否曾为PDF文件过大而烦恼?想要分享或上传文件时,却因为它的体积而束手无策?别担心,今天我将为大家分享一些简单实用的 PDF 压缩技巧,让你的文件轻松压缩pdf。 打开“轻云处理pdf官网”, 的网站。然后上…...

项目管理必备工具:2024年十大软件排行榜

有效的工具不仅可以帮助团队保持组织性,还能显著提高项目完成率。选择合适的项目管理软件,对于实现这些目标至关重要。 在2024年的各大权威榜单中,排名前十的项目管理软件包括:PingCode、Worktile(国内)&am…...

SOLIDWORKS专业版2024价格

SOLIDWORKS Professional 专业版,带有 ECAD/MCAD 协作、自动成本估算、协作功能、设计和工程图检查、复杂的零部件库以及高级真实感渲染。 1. ECAD/MCAD协作:SOLIDWORKS专业版提供了强大的ECAD/MCAD协作功能,使得设计团队可以更高效地进行跨…...

【外快业务】百度网盘扫码源码系统部署过程记录。

视频地址:【【自动发货项目】电脑PC/移动端扫码登录百度网盘项目源码,支持多人组团购买源码】 https://www.bilibili.com/video/BV1oD421W7oj/?share_sourcecopy_web&vd_source74cf265c4965f8c17f8e89bd8c29408d 1.远程连接服务器执行,…...

lucene原理

一、正排索引 Lucene的基础层次结构由索引、段、文档、域、词五个部分组成。正向索引的生成即为基于Lucene的基础层次结构一级一级处理文档并分解域存储词的过程。 索引文件层级关系如图1所示: 索引:Lucene索引库包含了搜索文本的所有内容&#xff0…...

华为、H3C交换机常用巡检命令

一、硬件状态、IOS版本信息检查 • display clock:显示系统时间。 • display version:查看交换机的版本信息和最近一次重新启动的时间。 • display enviroment:显示设备温度。 • display device:显示单板运行状态。 • di…...

网络安全 DVWA通关指南 SQL Injection(SQL注入)

DVWA SQL Injection 文章目录 DVWA SQL InjectionLowMediumHighImpossible SQL注入漏洞基本原理 Web应用程序对用户输入的数据校验处理不严或者根本没有校验,致使用户可以拼接执行SQL命令。 可能导致数据泄露或数据破坏,缺乏可审计性,甚至导致…...

【Linux】版本

文章目录 linux版本1、linxu技术版本(内核版本)2、linux商业化版本(发行版本) 区别 linux版本 1、linxu技术版本(内核版本) 内核:提供硬件抽象层、硬盘及文件系统控制及多任务功能的系统核心程…...

代码随想录算法训练营day47

题目:188.买卖股票的最佳时机IV、309.最佳买卖股票时机含冷冻期、714.买卖股票的最佳时机含手续费 参考链接:代码随想录 188.买卖股票的最佳时机IV 思路:本题和上题的最多两次买卖相比,改成了最多k次,使用类似思路&…...

【Android面试八股文】Kotlin内置标准函数apply的原理是什么?

文章目录 一、原理解析二、 示例代码2.1 具体示例应用场景2.2 为什么使用 `apply`?apply 是 Kotlin 标准库中的一个高阶函数,它的作用是在对象上执行一个代码块,并返回这个对象本身。其原理涉及到函数类型和接收者对象的结合使用。 一、原理解析 函数类型与接收者对象的结合…...

RegionClip环境安装踩坑指南

RegionClip环境安装 RegionClip环境安装)问题1问题2问题3问题4问题5 RegionClip环境安装) 特别强调,不要单独去安装detectron2,会出现model.clip不存在的错误,通过python -m pip install -e RegionCLIP就可以问题1 问题:torch-c…...

MySQL数据类型、运算符以及常用函数

MySQL数据类型 MySQL数据类型定义了数据的大小范围,因此使用时选择合适的类型,不仅会降低表占用的磁盘空间, 间接减少了磁盘I/O的次数,提高了表的访问效率,而且索引的效率也和数据的类型息息相关。 数值类型 浮点类型…...

零门槛NAS搭建:WinNAS如何让普通电脑秒变私有云?

一、核心优势:专为Windows用户设计的极简NAS WinNAS由深圳耘想存储科技开发,是一款收费低廉但功能全面的Windows NAS工具,主打“无学习成本部署” 。与其他NAS软件相比,其优势在于: 无需硬件改造:将任意W…...

C++_核心编程_多态案例二-制作饮品

#include <iostream> #include <string> using namespace std;/*制作饮品的大致流程为&#xff1a;煮水 - 冲泡 - 倒入杯中 - 加入辅料 利用多态技术实现本案例&#xff0c;提供抽象制作饮品基类&#xff0c;提供子类制作咖啡和茶叶*//*基类*/ class AbstractDr…...

rknn优化教程(二)

文章目录 1. 前述2. 三方库的封装2.1 xrepo中的库2.2 xrepo之外的库2.2.1 opencv2.2.2 rknnrt2.2.3 spdlog 3. rknn_engine库 1. 前述 OK&#xff0c;开始写第二篇的内容了。这篇博客主要能写一下&#xff1a; 如何给一些三方库按照xmake方式进行封装&#xff0c;供调用如何按…...

从零实现富文本编辑器#5-编辑器选区模型的状态结构表达

先前我们总结了浏览器选区模型的交互策略&#xff0c;并且实现了基本的选区操作&#xff0c;还调研了自绘选区的实现。那么相对的&#xff0c;我们还需要设计编辑器的选区表达&#xff0c;也可以称为模型选区。编辑器中应用变更时的操作范围&#xff0c;就是以模型选区为基准来…...

遍历 Map 类型集合的方法汇总

1 方法一 先用方法 keySet() 获取集合中的所有键。再通过 gey(key) 方法用对应键获取值 import java.util.HashMap; import java.util.Set;public class Test {public static void main(String[] args) {HashMap hashMap new HashMap();hashMap.put("语文",99);has…...

Debian系统简介

目录 Debian系统介绍 Debian版本介绍 Debian软件源介绍 软件包管理工具dpkg dpkg核心指令详解 安装软件包 卸载软件包 查询软件包状态 验证软件包完整性 手动处理依赖关系 dpkg vs apt Debian系统介绍 Debian 和 Ubuntu 都是基于 Debian内核 的 Linux 发行版&#xff…...

【位运算】消失的两个数字(hard)

消失的两个数字&#xff08;hard&#xff09; 题⽬描述&#xff1a;解法&#xff08;位运算&#xff09;&#xff1a;Java 算法代码&#xff1a;更简便代码 题⽬链接&#xff1a;⾯试题 17.19. 消失的两个数字 题⽬描述&#xff1a; 给定⼀个数组&#xff0c;包含从 1 到 N 所有…...

Cinnamon修改面板小工具图标

Cinnamon开始菜单-CSDN博客 设置模块都是做好的&#xff0c;比GNOME简单得多&#xff01; 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...

DIY|Mac 搭建 ESP-IDF 开发环境及编译小智 AI

前一阵子在百度 AI 开发者大会上&#xff0c;看到基于小智 AI DIY 玩具的演示&#xff0c;感觉有点意思&#xff0c;想着自己也来试试。 如果只是想烧录现成的固件&#xff0c;乐鑫官方除了提供了 Windows 版本的 Flash 下载工具 之外&#xff0c;还提供了基于网页版的 ESP LA…...

css3笔记 (1) 自用

outline: none 用于移除元素获得焦点时默认的轮廓线 broder:0 用于移除边框 font-size&#xff1a;0 用于设置字体不显示 list-style: none 消除<li> 标签默认样式 margin: xx auto 版心居中 width:100% 通栏 vertical-align 作用于行内元素 / 表格单元格&#xff…...