簡體   English   中英

Pandas - 如何使用 2 個不同的鍵按 2 個不同的列對值進行排序

[英]Pandas - How to sort_values by 2 different columns using 2 different keys

Pandas 1.1.0 key參數添加到sort_values

是否可以按 2 個不同的列排序,並為每個列使用不同的key

如果不是 - 實現相同行為的最佳方法是什么?

在你的第一個sort_values

df.groupby('col1').apply(lambda x: x.sort_values('col2',ascending=False)).reset_index(level=0, drop=True)

是的,這是可行的! 訣竅是讓鍵包含排序中使用的所有值

這是一個例子:

def make_sorter(l):
    sort_order = {k:v for k,v in zip(l, range(len(l)))}
    return lambda s: s.map(lambda x: sort_order[x])

a = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday']
b = ['Windows', 'Android', 'iPhone', 'Macintosh', 'iPad', 'ChromeOS', 'Linux']
df.sort_values(by=['days','device'], key=make_sorter(a+b), inplace=True)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM