首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何根据python中的特定条件对值进行排序?

如何根据python中的特定条件对值进行排序?
EN

Stack Overflow用户
提问于 2020-07-17 15:16:53
回答 2查看 122关注 0票数 1

我有一份数据

代码语言:javascript
复制
import pandas as pd
import numpy as np

df = pd.DataFrame({'Date':['01-01-2020','01-01-2020','01-01-2020','01-01-2020','01-01-2020'],
                  'Shift':['A','A','A','A','A'],
                  'heat_number':['HA1','HA10','HA8','HA18A','HA5']})

看上去像这样

代码语言:javascript
复制
    Date        Shift   heat_number
0   01-01-2020    A        HA1
1   01-01-2020    A        HA10
2   01-01-2020    A        HA8
3   01-01-2020    A        HA18A
4   01-01-2020    A        HA5
5   01-01-2020    A        HA18

如果我做了df.sort_values(['Date','Shift',heat_number]),就会得到以下输出:

代码语言:javascript
复制
    Date         Shift  heat_number
0   01-01-2020    A        HA1
1   01-01-2020    A        HA10
5   01-01-2020    A        HA18
3   01-01-2020    A        HA18A
4   01-01-2020    A        HA5
2   01-01-2020    A        HA8

但我想要的输出是:

代码语言:javascript
复制
    Date         Shift  heat_number
0   01-01-2020    A        HA1
4   01-01-2020    A        HA5
2   01-01-2020    A        HA8
1   01-01-2020    A        HA10
5   01-01-2020    A        HA18
3   01-01-2020    A        HA18A

热数列中的过滤器不符合预期。我怎么才能解决这个问题?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-07-17 15:26:24

您可以将新的psuedo列分配给dataFrame DataFrame.assign (提取heat_number ),在psuedo列上应用sort_values。最后,drop psuedo列

代码语言:javascript
复制
(
    df.assign(sort_by=df.heat_number.str.extract("(\d+)").astype(int))
        .sort_values(by="sort_by")
        .drop(columns="sort_by")
)

代码语言:javascript
复制
         Date Shift heat_number
0  01-01-2020     A         HA1
4  01-01-2020     A         HA5
2  01-01-2020     A         HA8
1  01-01-2020     A        HA10
3  01-01-2020     A       HA18A
票数 1
EN

Stack Overflow用户

发布于 2020-07-17 15:25:41

下面是我要做的事情:

代码语言:javascript
复制
df['len_heat']  = df.heat_number.str.len()

df = df.sort_values(['Date','Shift',"len_heat"])

del df['len_heat']

基本上,它添加了一个具有字符串长度的列,对该列进行排序和删除。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62956922

复制
相关文章

相似问题

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