在工作中,我们一般用excel或者SQL来处理和分析数据,本文分享了Pandas框架,给出该工具的使用方法,供大家参考。
以往数据分析常使用的工具是excel和sql,用这两个工具做过大数据分析的网友都能感受到那种痛苦,本文对Python的Pandas大数据分析工具做架构分析,以方便掌握该强大的工具本文的架构分析是通过阅读pandas中文出版物教程、互联网搜索、代码验证的基础上得到的结构猜想,并没有深入源代码分析,实际架构与本分析可能略有出入,请知悉。
1. 结构概览
Pandas就是数据容器,容器好不好用,不仅取决于容器能装多少东西,更取决于,取出来是否方便Pandas的Series和DataFrame作为数据容器就像一本书数组容器:就是这本书只有页码如果书本不超过几百页,或者使用的很少,使用起来并没有问题,如果书本有十万页,频繁找东西时肯定就麻烦了。
数据分析就像在几十万、几百万页的书本里,找数据,只有页码是不够用的Index容器:Index是对数组容器页码的拓展,在原页码的基础上增加了文本描述,读者对频繁使用的章节可以夹个标签Index容器有很多子类型,可以简化索引的使用,如:DatetimeIndex、PeriodIndex、IntervalIndex等。
MultiIndex容器:是对Index容器的组合,不仅支持一层便签,可以支持任意层便签,通过该容器可以实现目录管理Series是一列数据值,DataFrame是N列数据是,是N个Series的组合Series和DataFrame从容器的角度,主要拓展的是索引部分,两者的分为index和values两部分,其中index是索引,有复杂的各种实现类。
values仍是ndarray类型
2. Series
Series是对数组的封装,比普通数组新增index的属性不考虑MultIndex的场景该图是准确的,考虑MultiIndex,书签信息可以有无数列数据2.1 数据初始化Series的两列位置信息,页码信息是系统自动编码,无法人工介入。
书签信息是手动编码,可以指定也可以不指定
索引列和对象可以单独起名字。value没有名字
2.2 通过Index定位值数组支持按位置访问,比如s[1]Series支持按位置和按index访问两种方式。
Series传入的标签参数可以换算为位置信息loc和iloc返回值是向量at和iat返回值为标量位置信息的使用,用SQL表达就是:from 原表 where index.loc in or index.lable in。
2.3 通过值定位Index
函数返回值为bool类型的Series要得到index值或者数据向量,需要再调用一次se.loc此处函数的使用,用SQL表达就是:from 原表 y left join BoolSeries yi where y.index = yi.index and yi.value =True
2.4 MultiIndex构建Index和MultiIndex都是数组,数组的个数=数据的行数Index数组的元素是标量数值MultiIndex的数组元素是元组,可以是二元组、三元组、四元组等
这里的目录操作,也是人工智能算法打标签的地方,打好标签就可以分群,就可以推荐了对于Series由于只有一列数据,所有列的层级就没有建目录的功能,DataFrame有此功能2.5 时间构建目录时间可以按年、月、日、时、分这五个维度构成一个目录层级结构,可以用目录实现。
直接使用DatetimeIndex对象构建:
3. DataFrame
DataFrame是有多个Series或数组联表而成的组装表Series和数组的组装方式分为三种场景,每种场景有几种存在的组合,如图,绿色的组合场景是合法的,白色的组合场景是非法的3.1 多个数组合并
数组和DataFrame的维度信息对照:数组是有序的,所以有位置信息,位置信息是隐含的隐式对应于DataFrame的index属性数组是有值的,所以有数值信息,数值信息是显式的显式对应DataFrame的value属性。
数组和DataFrame的存储值对照:数组的值存储的是地址,所以数组可容纳数值、字符串、对象等任意类型DataFrame每列存储的类型是固定的,所以DataFrame组装时,会自动转换数据类型组装关系用SQL表示为:。
原则猜测:之所以数组组装要求严格,是因为数组本身很灵活,数据清洗程度低,数据脏乱差的概率更大,所以此处严格校验,可以降低数据错误的风险。3.2 多个Series合并
多个series组成DataFrame实际执行的是连表操作,效果等同于Sql语句的全连接3.3 Series和数组合并只要有数组存在,就必须完全对齐,索引列使用Series的索引列系统默认Series和数组的索引列按照所在顺序建立联表关系。
当Series和数组组成DataFrame时,按照从严法则,必须上下对齐4. 数据分组分组是根据索引将数据聚合,两种方法:显式声明索引,可以直接使用索引分组不声明索引,调用groupby后自动创建索引分组有三个维度:
行维度分组:groupby行维度分组+列维度分组:数据透视表 pivot按顺序,固定行数组成窗口分组:rolling、expanding4.1 显式声明索引后分组
4.2 分组后自动创建索引
4.3 行维度分组
4.4 行列两维度分组4.4.1 单行单列写法
4.4.2 多行单列写法
4.4.3 多行多列写法
4.5 窗口滚动分组滚动分组是按照位置数量分组,实际工作中常说的过去1年,过去一个月,过去一周,以及时间函数都使用滚动计算的理念。
窗口函数与窗口累计函数都可以使用apply函数拿到窗口的值数组,可以使用该值,做任意匹配的运算。
4.6 窗口累计分组
5. 改变数据形状Pandas中,处理的数据基本都是按表格组织,数据输入有两种方式,按行输入,按列输入为了输入方便基本会按长轴维度输入数据比如8行两列的数据,可以按照行的顺序写,也可以按照列的顺序写对于该数据,肯定是按列的顺序书写,需要输入的中括号最少。
数据输入后再处理即可
图中可知,数据调用zip分组后,从数据分组的角度看:zip和数据转置的效果是一致的。6. 数据查询逻辑Series和DataFrame作为数据容器,数据查询是很重要的逻辑,此处再系统梳理一下流程。
6.1 按索引取值按索引取值,类比于select的按照主键取值Pandas接受到入参索引后,会构建一个与被查询数据,相同索引的Series,其中被查询的索引对应值为True,未被查询的索引对应值为False,将该Series作为入参,查询效果与直接输入索引查询效果相同。
代码如下:
6.2 按值取值按照值取值时,每个运算符对应一个Bool。如果Bool之间是and关系,就执行b1*b2如果Bool之间是or关系,就执行b1+b2
7. 不同数据类型之间的转换逻辑
8. Index展开详解8.1 概述index是比数组更大的容器,数组内的元素可以是不同的类型,index统一定义了数组的类型,必须是obj、Datetime、int、Period等其中的一种index会猜测数组内存储的数据类型,如果是数值,会自动转换为对应的类型,否则统一定义为object类型。
定义object类型的好处是:可以存储任意类型的数据定义object类型的缺点是:大而全,就没有操作数据的方法小而精,才可以使用对应的操作方法为了调用int、Datetime类型数据对应的操作方法,需要显式的转换为对应的类型。
8.2 DatetimeIndexDatetimeIndex就是Datetime格式的index日期是一组连续的数字,默认可以按照年、月、日、时、分、秒分组,也可以自定义时间段分组如果某Series或者DataFrame需要使用年月日时分秒做分组依据,有两个方案:。
8.2.1 年月日时分组成5列数组,通过MultiIndex赋值将字符数组转为
8.2.2 直接将日期转为Datetimeindex赋值,用方法取值
两个对比,显然第二个方案更简单灵活9 .常用函数说明9.1 map与replace的等价写法map可以将任意值改名其他值,此处主要介绍将Bool转成文本因为在查询函数返回的值都为bool类型,所以此场景使用map函数的频率更高。
map的传参是集合,是因为这里传值是映射关系。
调用多次replace函数的效果与调用map函数的结果相同。9.2 isna与isin的等价写法
isna与isin(pd.NA)是等价的。fillna与replace(pd.Na)是等价的。
9.3 notna与notin的等价写法pandas没有not in函数。但是有波浪线表示取反,即True取反后是False,False取反后是True
9.4 列拆分函数splitSeries分列,默认是将内容分成,数组,不会展开。9.4.1 默认为Series格式
9.4.2 数据自动变成DataFrame格式
本文由 @我是产品张 原创发布于人人都是产品经理。未经许可,禁止转载题图来自Unsplash,基于CC0协议该文观点仅代表作者本人,人人都是产品经理平台仅提供信息存储空间服务。
亲爱的读者们,感谢您花时间阅读本文。如果您对本文有任何疑问或建议,请随时联系我。我非常乐意与您交流。
发表评论:
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。