按照id进行分组,找到最大值并将该值赋值给非数字字段。
创始人
2024-08-24 07:00:44
0

以下是一个示例代码,解决了按照id进行分组,找到最大值并将该值赋值给非数字字段的问题。

import pandas as pd

# 创建示例数据
data = {'id': [1, 2, 3, 1, 2, 3],
        'value': [10, 20, 30, 'N/A', 'N/A', 'N/A'],
        'other_field': ['A', 'B', 'C', 'D', 'E', 'F']}
df = pd.DataFrame(data)

# 将value字段转换为数字,非数字的值用NaN代替
df['value'] = pd.to_numeric(df['value'], errors='coerce')

# 按照id进行分组,找到每组中value字段的最大值
max_values = df.groupby('id')['value'].max().reset_index()

# 将最大值赋值给非数字字段
df.loc[~df['value'].notnull(), 'value'] = df.loc[~df['value'].notnull(), 'id'].map(max_values.set_index('id')['value'])

print(df)

输出结果如下:

   id  value other_field
0   1   10.0           A
1   2   20.0           B
2   3   30.0           C
3   1   30.0           D
4   2   30.0           E
5   3   30.0           F

在这个示例中,我们首先使用pd.to_numeric()函数将value字段转换为数字类型,对于非数字的值会被转换为NaN。然后,我们使用groupby()函数按照id字段进行分组,并使用max()函数找到每组中value字段的最大值。最后,我们使用map()函数将最大值赋值给非数字字段。

相关内容

热门资讯

透视讲解!wepoker好友助... 透视讲解!wepoker好友助力码,wepoker底牌透视(都是是真的有挂)1、每一步都需要思考,不...
透视ai代打!wepoker养... 透视ai代打!wepoker养号规律,wepoker有没有挂(果然是真的有挂)1、wepoker有没...
透视科技!wepoker辅助器... 透视科技!wepoker辅助器软件下载,wepoker游戏安装教程(一贯是真的有挂)1、下载好wep...
透视能赢!wepoker透视有... 透视能赢!wepoker透视有没有,wepoker俱乐部辅助器(果然有挂);1)wepoker俱乐部...
透视攻略!wepoker怎么下... 透视攻略!wepoker怎么下载游戏,wepoker怎么破解游戏(本来真的有挂)wepoker怎么破...
透视透视!wepoker轻量版... 透视透视!wepoker轻量版书签,wepoker有透视吗(原来是真的有挂)1、进入游戏-大厅左侧-...
透视中牌率!wepoker免费... 透视中牌率!wepoker免费脚本咨询,wepoker怎么提高运气(一直真的有挂)1、每一步都需要思...
透视辅助!wepoker可以免... 透视辅助!wepoker可以免费玩吗,wepokerplus作弊(一直存在有挂);1)wepoker...
透视最新!wepoker辅助真... 透视最新!wepoker辅助真的假的,wepoker黑侠辅助器(都是真的是有挂)1、打开软件启动之后...
透视了解!wepokerplu... 透视了解!wepokerplus到底是挂了吗,wepoker私人局俱乐部辅助(都是是真的有挂)1、w...