python pandas 过滤数据

dataframe

     A     B     C       D
1  326  0.00  0.00      10
2  326  0.00  0.00       0
6   63  0.00  2.43      82
5   63  0.00  2.43   0.082
3   63  0.00  2.43  0.0082
4   63  0.00  2.43   0.002

按C列分组,保留D列最小的值
结果是:

2  326  0.00  0.00       0
4   63  0.00  2.43   0.002

使用如下

c = df.groupby('C').filter(lambda x: x.min(['D']))

提示出错

TypeError: unhashable type: 'list'

利用pandas该怎么做能达到?

阅读 9.6k
2 个回答
c = df.groupby('C').min()['D']

图片描述

应该是这样的写法,如果坚持用lambda x

c = data.groupby('C').apply(lambda x: x['D'].min())

print(c)
C
0.00    0.000
2.43    0.002
dtype: float64
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题