[英]How to sort array of string and int values, multiple attributes with alphabetical and “reversed”-alphabetical order
我有一個包含[name, surname, int1, int2]
元素的數組,我需要按此順序對其進行排序:
通過int1
(減少)。
如果int1
是相同的,排序name
中的“逆轉” -alphabetical秩序。
如果name
相同, surname
字母順序按surname
排序。
所以我有這個:
print(sorted(a, key = lambda x: [-int(x[2]), x[0], x[1]]))
我不知道如何排序x[0]
在反向字母順序-x[0], x[0][::-1]
不為我工作。
例:
[('Petia', 'Anja', 3, 0),
('Vasia', 'Katia', 3, 0),
('Petia', 'Katia', 3, 0),
('Kolia', 'Alexey', 10, 0),
('Yana', 'Anja', 10, 0)]
至
[('Yana', 'Anja', 10, 0),
('Kolia', 'Alexey', 10, 0),
('Vasia', 'Katia', 3, 0),
('Petia', 'Anja', 3, 0),
('Petia', 'Katia', 3, 0)]
您可以創建一個具有<
( <
所有CPythons sorted
需求的實現 - 的實現的類 - 如果您使用其他Python實現,則可能需要其他比較運算符)。 這允許完全控制“排序”。 例如:
class Sorter(object):
def __init__(self, tup):
self.name, self.surname, self.int1, self.int2 = tup
def __lt__(self, other):
# Just to make the logic clearer, in practise you could do nest the ifs
# to avoid computing self.int1 == other.int1 twice
if self.int1 == other.int1 and self.name == other.name:
return self.surname < other.surname
elif self.int1 == other.int1:
return self.name > other.name
else:
return self.int1 > other.int1
然后使用它作為sorted
key
:
>>> sorted(a, key=Sorter)
[('Yana', 'Anja', 10, 0),
('Kolia', 'Alexey', 10, 0),
('Vasia', 'Katia', 3, 0),
('Petia', 'Anja', 3, 0),
('Petia', 'Katia', 3, 0)]
>>> intab='abcdefghijklmnopqrstuvwxyz'
>>> tab = string.maketrans(intab+intab.upper(), intab[::-1]+intab.upper()[::-1])
>>>
>>> slst = sorted(lst, key = lambda x: [-int(x[2]), x[0].translate(tab), x[1]])
>>> pprint(slst)
[('Yana', 'Anja', 10, 0),
('Kolia', 'Alexey', 10, 0),
('Vasia', 'Katia', 3, 0),
('Petia', 'Anja', 3, 0),
('Petia', 'Katia', 3, 0)]
>>>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.