dataframe中如何得到按列分组后另一列的第n大的值?
df = pd.DataFrame({'fruit': ['apple', 'banana', 'orange'] * 2,
'taste': np.random.rand(6),
'price': np.random.randint(0, 15, 6)})
print(df)
# teste列按fruit分组
df_grpd = df['taste'].groupby(df.fruit)
# teste列中banana元素的信息
x=df_grpd.get_group('banana')
# 排序并找第2大的值
s = x.sort_values().iloc[-2]
print(s)
#> fruit taste price
0 apple 0.521990 7
1 banana 0.640444 0
2 orange 0.460509 9
3 apple 0.818963 4
4 banana 0.646138 7
5 orange 0.917056 12
#> 0.6404436436085967
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。