具有GROUPBY的多列上的VALUE_COUNTS [英] Value_counts on multiple columns with groupby

查看:31
本文介绍了具有GROUPBY的多列上的VALUE_COUNTS的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我需要一些 pandas 方面的帮助。

我有以下数据帧:

df = pd.DataFrame({'1Country': ['FR', 'FR', 'GER','GER','IT','IT', 'FR','GER','IT'],
               '2City': ['Paris', 'Paris', 'Berlin', 'Berlin', 'Rome', 'Rome','Paris','Berlin','Rome'],
               'F1': ['A', 'B', 'C', 'B', 'B', 'C', 'A', 'B', 'C'],
               'F2': ['B', 'C', 'A', 'A', 'B', 'C', 'A', 'B', 'C'],
               'F3': ['C', 'A', 'B', 'C', 'C', 'C', 'A', 'B', 'C']})

screenshot

我正在尝试对前两列1Country2City执行groupby,对列F1F2执行value_counts。到目前为止,我使用

一次只能对一个列执行GROUPBY ANDvalue_counts
df.groupby(['1Country','2City'])['F1'].apply(pd.Series.value_counts)

如何对多列执行value_counts并获得数据框结果?

推荐答案

您可以使用agg,内容大致如下:

df.groupby(['1Country','2City']).agg({i:'value_counts' for i in df.columns[2:]})

               F1   F2   F3
FR  Paris  A  2.0  1.0  2.0
           B  1.0  1.0  NaN
           C  NaN  1.0  1.0
GER Berlin A  NaN  2.0  NaN
           B  2.0  1.0  2.0
           C  1.0  NaN  1.0
IT  Rome   B  1.0  1.0  NaN
           C  2.0  2.0  3.0

这篇关于具有GROUPBY的多列上的VALUE_COUNTS的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆