matlab table数据结构,关于MATLAB table数据结构的分析介绍

本文介绍MATLAB中引入的table数据类型,它是为工程计算设计的高效表状数据结构,能替代旧的dataset。table支持不同类型数据存储,包括字符型和数值型,以及如何通过readtable函数导入CSV并处理表头。通过实例演示table的构造、访问和实际应用场景。
摘要由CSDN通过智能技术生成

MATLAB常用基本数据类型有:整型,浮点型,字符型,函数句柄,元胞数组和结构体数组。除了这些基本数据类型,MATLAB还有很多其它的数据类型不为人熟悉,这些数据类型在编程中也非常有用。MATLAB高级数据类型系列旨在向大家介绍它们:比如containers.Map,tables,enumeration和timeseries等等,它们为什么有用,用来解决什么问题,并且怎样在科学工程计算中怎么使用。上篇我们提到了映射表结构(containers.Map)。本篇将介绍另一中新的MATLAB数据类型--table。

table简介

为什么需要table数据结构

MathWorks在MATLABR2013b中引入了一种新的数据结构叫做table。table类似统计工具箱中的dataset,其引入的目的就是用来取代dataset的数据类型。因为表状的数据在工程计算中越来越长久,有了table类型,MATLAB用户就可以不用购买统计工具箱,也能使用表状的数据结构了。table本质上来说是一种可以存放各种数据类型的容器,比如下面表Table.1中的数据,其中既有字符型,又有数值类型,其中第一行作为表头:Symbol,Name,Market,Cap,IPO,Year是各列的名字。

29f955e441d72cfcf4ace4f93ec57d08.png

Table.1NASDAQ股票名称表

在conatiners.Map的章节中,我们介绍了MATLAB的基本数据类型(比如数组,原胞数组和结构体)在表达某些复杂数据类型时的局限性。这里不再一一赘述,读者只需要认识到:数组的局限性在于不能用来存放数值以外的数据,而使用元胞读取和索引内容时有种种不方便,比如无法区分该数据中的表头和其余的行数据。事实上,如果数据存放在如下的CSV文件中,并且用importdata直接读取CSV文件。

e9417a053e1dc53cefb20ca0f60f5890.png

显然这不是我们所期待的要导入格式。

通过导入数据构造table对象

沿用上一步的CVS文件,我们可以使用readtable函数,构造一个新的table对象,把csv文件中的数据导入到该对象中。readtable函数接受文件名称作为输入,返回一个table对象。

0dec6f5d5289e84341aa4ae91941c8d8.png

注意第2行的warning,因为readtable函数把nasdaq.csv中的第一行自动变成了这个table的表头,在创建table对象的时候,MATLAB会对做表头的文字做处理,这里把MarketCap和IPOYear两个词中的空格去掉,缩成一个词,这样做是为了方便将来使用dot语法来访问表中的数据。因为MATLAB修改了原来的表头,所以这里给出了warning。

调用table构造函数来构造table对象

通过转换函数构造table对象

访问table中的数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值