微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

python – 使用pandas groupby获取与最小值对应的行

我有一个表需要按条件分组:

R_num ORG name level
13    Dm   Ad   17
13    Dm   Af   16

当我使用它给我13 Dm Ad 16,这就像被操纵的数据.

df1=df.reset_index().groupby(['R_num','ORG']).agg({'name':'first','level':['min']})

我想要的结果是13 Dm Af 16,我知道’name’可能有问题:’first’但我该怎么办呢?

谢谢

解决方法:

IIUC,你应该使用groupby和idxmin:

# df.loc[df.groupby(['R_num','ORG'])['level'].agg('idxmin')]
df.loc[df.groupby(['R_num','ORG'])['level'].idxmin()]

   R_num ORG name  level
1     13  Dm   Af     16

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐