我有以下数据框:
df = pd.DataFrame({'Farmer': ['John', 'Nick', 'Jane', 'Jane', 'John', 'Jane', 'John', 'Nick'],
'Animal': ['Cow', 'Sheep', 'Dolphin', 'Sheep', 'Horse', 'Dinosaur', 'Pig', 'Horse'],
'Weight': [200, 50 , 90 , 56, 180, 160, 150, 175]})
Farmer Animal Weight
0 John Cow 200
1 Nick Sheep 50
2 Jane Dolphin 90
3 Jane Sheep 56
4 John Horse 180
5 Jane Dinosaur 160
6 John Pig 150
7 Nick Horse 175
我想按'Farmer'列对数据框进行分组,然后将每个农民的 3 只最大动物的重量分为 3 列。
Farmer top1_animal_weight top2_animal_weight top3_animal_weight
0 John 200 180 150
1 Nick 175 50 NaN
2 Jane 160 90 56
首先,我尝试将方法应用于每个组,但当没有第三大元素时nlargest它不会返回。NaN而且我也不知道如何将一个重量列转换为三个
缥缈止盈
相关分类