您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

python – 使用pandas按组获取计数

5b51 2022/1/14 8:20:27 python 字数 1723 阅读 456 来源 www.jb51.cc/python

参见英文答案 > How to pivot a dataframe????????????????????????????????????1个 我有一个pandas数据框,其中包含如下所示的数据: ID year_month_id Class 1 201612 A 2 201612 D 3 201612 B 4 20161

概述

ID  year_month_id   Class
1   201612          A
2   201612          D
3   201612          B
4   201612          Other
5   201612          Other
6   201612          Other
7   201612          A
8   201612          Other
9   201612          A
1   201701          B

因此,ID可以在特定月份的任何课程中,下个月他的课程可能会发生变化.
现在我要做的是为每个ID获取它在特定类下的月数以及它所属的最新类.如下所示:

ID  Class_A Class_B Class_D Other Latest_Class
1   2        3       4         0    B
2   12       0       0         0    D

我如何在python中实现这一点.
有人可以帮我这个吗?
此外,由于真实数据集很大并且无法手动验证,我如何才能获得超过1类的ID列表?

ndf = df.pivot_table(index=['ID'],columns=['Class'],aggfunc='count',fill_value=0)\
    .xs('year_month_id',axis=1,drop_level=True)

ndf['latest'] = df.sort_values('ID').groupby('ID')['Class'].tail(1).values

Class  A  B  D  Other latest
ID                          
1      1  1  0      0      B
2      0  0  1      0      D
3      0  1  0      0      B
4      0  0  0      1  Other
5      0  0  0      1  Other
6      0  0  0      1  Other
7      1  0  0      0      A
8      0  0  0      1  Other
9      1  0  0      0      A

总结

以上是编程之家为你收集整理的python – 使用pandas按组获取计数全部内容,希望文章能够帮你解决python – 使用pandas按组获取计数所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶