首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >仅为一列排序值时使用键

仅为一列排序值时使用键
EN

Stack Overflow用户
提问于 2021-02-19 21:59:28
回答 1查看 40关注 0票数 1

假设我们有一个如下的df:

代码语言:javascript
运行
复制
df = pd.DataFrame({'A':['y2','x3','z1','z1'],'B':['y2','x3','a2','z1']})

    A   B
0   y2  y2
1   x3  x3
2   z1  a2
3   z1  z1

如果我们只想根据A列中的数字对值进行排序,我们可以这样做:

代码语言:javascript
运行
复制
df.sort_values(by='A',key=lambda x: x.str[1])

    A   B
3   z1  z1
2   z1  a2
0   y2  y2
1   x3  x3

如果我们想同时按列AB排序,但只将键应用于列A,有没有办法做到这一点?

代码语言:javascript
运行
复制
df.sort_values(by=['A','B'],key=lambda x: x.str[1])

预期输出:

代码语言:javascript
运行
复制
    A   B
2   z1  a2
3   z1  z1
0   y2  y2
1   x3  x3
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-19 22:11:03

您可以先按B排序,然后使用稳定的方法按A排序:

代码语言:javascript
运行
复制
(df.sort_values('B')
   .sort_values('A', key=lambda x: x.str[1], kind='mergesort')
)

输出:

代码语言:javascript
运行
复制
    A   B
2  z1  a2
3  z1  z1
0  y2  y2
1  x3  x3
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66278976

复制
相关文章

相似问题

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