gpt4 book ai didi

python - 分组依据和其他列值 pandas 的计数

转载 作者:太空宇宙 更新时间:2023-11-04 01:47:02 26 4
gpt4 key购买 nike

我有一个 Pandas 数据框

age   gender   criticality    acknowledged       
10 Male High Yes
10 Male High Yes
10 Male High Yes
10 Male Low Yes
11 Female Medium No

我想按年龄和性别分组,然后将“criticality”、“acknowledged”的值作为新列并获取计数。

例如,我想要的输出是:

                 criticality          acknowledged
age gender High Medium Low Yes No
10 Male 3 0 1 4 0
11 Female 0 1 0 0 1

我想到了使用 df.groupby(['age','gender'])['criticality','acknowledged'].stack()

但它不起作用。

有没有更好的方法来获得这种格式的结果

最佳答案

由于您分别对两列进行计数,因此 concat 将是一个简单的解决方案:

In [13]: pd.concat([df.pivot_table(index=['age', 'gender'], columns=col, aggfunc
...: =len) for col in ['criticality', 'acknowledged']], axis=1).fillna(0)
Out[13]:
acknowledged criticality
criticality High Low Medium No Yes
age gender
10 Male 3.0 1.0 0.0 0.0 4.0
11 Female 0.0 0.0 1.0 1.0 0.0

关于python - 分组依据和其他列值 pandas 的计数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58874626/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com