Python CategoricalDtype自定义排序实现原理解析
作者:秋天中的一片叶 时间:2021-05-31 22:30:32
CategoricalDtype自定义排序
当我们的透视表生成完毕后,有很多情况下需要我们对某列或某行值进行排序。排序有很多种方法。例如sort_index及sort_values函数也可以对数据进行排序,这里就不多说了。
对于数值和字母的排序很容易,但是对于中文的排序就有点麻烦了。默认情况下是按照utf-8的编码来进行排序的但是即使如此也很难满足我们对汉字排序的要求。所以通过CategoricalDtye可以把数据类型转成Category类型
然后通过指定参数列表的顺序来自定义那个元素先那个元素后,完全取决于你把那个元素放在List的前面,这样就大大方便了我们对中文排序的操作。
代码如下:
1. 自动生成DataFrame数据
#%%
import pandas as pd
from datetime import datetime
city =["上海","北京","深圳","杭州","苏州","青岛","大连","齐齐哈尔","大理","丽江",
"天津","济南","南京","广州","无锡","连云港","张家界"]
#创建自动从list中选取valuse值的get_list函数
#replace=True代表允许选出的元素重复
def get_list(items,size=20):
return pd.Series(items).sample(n=size,replace=True).to_list()
#通过get_list自动生成数据,最终生成一个DataFrame
df = pd.DataFrame({
"城市":get_list(city),
"仓位":get_list(["经济舱","商务舱","头等舱"]),
"航线":get_list(["单程","往返"]),
"日期": get_list([datetime(2020,8,1),datetime(2020,8,2),
datetime(2020,8,3),datetime(2020,8,4)]),
"时间": get_list(["09:00 - 12:00",
"13:00 - 15:30",
"06:30 - 15:00",
"18:00 - 21:00",
"20:00 - 23:20",
"10:00 - 15:00"]),
"航空公司": get_list(["东方航空","南方航空","深圳航空","山东航空","中国航空"]),
"出票数量":get_list([10,15,20,25,30,35,40,45,50,55,60]),
})
#%%
df
结果如下:
2. 查看数据类型
#%%
df.dtypes
3. 自定义数据类型(Category)按照指定顺序排序,并通过透视表展示数据
#%%
#自定义type,以及自定义排序的顺序
my_type = pd.CategoricalDtype(
categories=["头等舱","商务舱","经济舱"],
ordered=True
)
df["仓位"] = df["仓位"].astype(my_type) #将指定列转成自定义的type
df.dtypes
#%%
#通过透视表统计数据
tb = pd.pivot_table(
df,
index=["城市","仓位","航线","日期","时间"],
values="出票数量",
aggfunc=sum
)
tb
先查看数据类型:可以看出仓位的数据类型已经从Object变成了category类型了。
结果为:
分析上述数据可以看出,我们把仓位按照["头等舱","商务舱","经济舱"]的顺序进行了排序,排序结果也是按照这个顺序排列的,成功的满足了我们对中文列自定义排序的需求。
通过Pivot_table函数更加清晰的对原有数据进行了展示。也可以按照自己的需求展示其中的一部分数据。这样对数据的清洗及展示变得更加的灵活。
来源:https://www.cnblogs.com/liupengpengg/p/13559861.html
标签:Python,Categorical,Dtype,自定义,排序
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
python入门:argparse浅析 nargs='+'作用
2023-06-26 15:52:58
![](https://img.aspxhome.com/file/2023/4/59284_0s.jpg)
Python ChineseCalendar包主要类和方法详解
2021-10-12 10:40:40
python-yml文件读写与xml文件读写
2022-06-16 06:43:50
![](https://img.aspxhome.com/file/2023/9/67919_0s.png)
PHP实现逐行删除文件右侧空格的方法 <font color=red>原创</font>
2023-11-22 05:11:25
解决Python logging模块无法正常输出日志的问题
2023-10-03 17:04:25
良好体验,必须是全方位的
2009-09-24 13:32:00
![](https://img.aspxhome.com/file/UploadPic/20099/24/15-37s.png)
python 解析html之BeautifulSoup
2021-02-09 23:09:12
Python中拆分具有多个分隔符的字符串方法实例
2022-07-01 00:38:20
![](https://img.aspxhome.com/file/2023/0/81720_0s.png)
python自制包并用pip免提交到pypi仅安装到本机【推荐】
2023-12-14 19:33:23
Python 提速器numba
2021-04-27 21:14:06
Python 使用 PyQt5 开发的关机小工具分享
2023-09-15 05:06:02
Python 递归式实现二叉树前序,中序,后序遍历
2022-09-22 17:38:32
![](https://img.aspxhome.com/file/2023/7/66777_0s.png)
Python科学画图代码分享
2023-08-19 07:06:25
![](https://img.aspxhome.com/file/2023/2/65532_0s.jpg)
如何将JSP/Servlet项目转换为Spring Boot项目
2023-06-19 16:23:06
![](https://img.aspxhome.com/file/2023/3/97883_0s.png)
python异常和文件处理机制详解
2023-12-13 11:46:13
详解如何利用Python绘制迷宫小游戏
2021-02-28 05:31:32
![](https://img.aspxhome.com/file/2023/5/66885_0s.gif)
利用Python实现绘制论文中的曲线图
2022-12-14 12:04:37
![](https://img.aspxhome.com/file/2023/9/78489_0s.png)
Python的动态重新封装的教程
2023-08-23 15:26:39
彻底解决MySql在UTF8字符集下乱码问题
2011-06-02 12:02:00
Python字符串的字符转换、字符串劈分、字符串合并问题分析
2021-07-22 19:14:24
![](https://img.aspxhome.com/file/2023/0/72960_0s.png)