首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Pandas -> DataFrame ->排名

Pandas -> DataFrame ->排名
EN

Stack Overflow用户
提问于 2021-10-10 12:49:55
回答 2查看 48关注 0票数 0

我有一个DataFrame,我试图在其中添加一个新的“排名”列,通过比较价格(列“价格”)来确定相对于“名称”和“国家”列的价格评级。但没有成功。我需要下面的结果,截图如下。请帮帮忙,我将不胜感激

EN

回答 2

Stack Overflow用户

发布于 2021-10-10 12:56:33

试试这个:

代码语言:javascript
运行
复制
df['rank'] = df.groupby('name')['price'].rank(ascending=False)
票数 2
EN

Stack Overflow用户

发布于 2021-10-10 13:06:01

IIUC,首先你需要在每个组中对价格进行排序,然后使用如下所示的排名:

代码语言:javascript
运行
复制
df['rank'] = df.groupby('name')['price'].apply(lambda x: x.sort_values().rank())
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69515291

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档