我有一个包含[name, surname, int1, int2]
元素的数组,我需要按以下顺序对其进行排序:
通过int1
(减少)。
如果int1
相同,请按name
的字母顺序以“倒转”的顺序排序。
如果name
相同,则按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)]
答案 0 :(得分:4)
您可以创建一个带有<
实现的类(<
是sorted
所需的所有CPython-如果您使用的是另一个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
然后将其用作key
的{{1}}:
sorted
答案 1 :(得分: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)]
>>>