pandas - 在 groupby 结果后使用 value_counts() 透视数据帧
问题描述
我已经尝试了很多,但找不到解决方案。
我在我的 df 上运行此代码:
df.groupby(df['Operatiejaar'])['ASA'].value_counts().sort_index()
这具有预期的结果:
Operatiejaar ASA
2017 1.0 1523
2.0 2658
3.0 685
4.0 28
2018 1.0 1357
2.0 2749
3.0 729
4.0 26
2019 1.0 1505
2.0 2770
3.0 787
4.0 27
5.0 1
Name: ASA, dtype: int64
现在,我想将其转为:
ASA 1 ASA 2 ASA 3 ASA 4
Jaar
2017 1523 2658 685 28
2018 1357 2749 729 26
2019 1505 2770 787 27
我现在手工制作了这个 pivot.df。我的问题是:基于上面的 groupby 代码:如何将结果转换为想要的 df?我相信这一定可以,但是如何....顺便说一句:groupby的结果是一个Series。使用 pd.DataFrame(df) 我已将其转换为 DataFrame。
谢谢!!问候一月
解决方案
使用Series.unstack
,然后将列名转换为整数并最后使用DataFrame.add_prefix
:
s = df.groupby(df['Operatiejaar'])['ASA'].value_counts().sort_index()
df1 = s.unstack().rename(columns=int).add_prefix('ASA ')
如果每组只需要前 4 行,请添加GroupBy.head
:
df1 = s.groupby(level=0).head(4).unstack().rename(columns=int).add_prefix('ASA ')
推荐阅读
- angular - 转换路由参数:Angular Resolver
- javascript - 如何在 trumbowyg 中为多个图像设置宽度和高度?
- mysql - 如何在 Google Data Studio 自定义查询中解密来自 mySQL 的数据
- d3.js - 嵌入 csv 文件或将数据直接放入 d3 可视化代码中
- python - 无法从 RDD 创建数据框
- javascript - 如何在 React 中编写 txt 文件?
- vb.net - 如果 IF 语句在 VB 中为真,如何停止程序?
- android - Flutter build Appbundle 错误:* 出了什么问题:评估项目“:app”时出现问题
- sql - 间接复制外键?
- java - Spring Cloud Config vs Spring Cloud Consul Config KV