我有一个包含 [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)]
最佳答案
您可以创建一个实现 <
的类( <
是 CPython 的所有 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
然后将其用作 key
对于 sorted
:
>>> sorted(a, key=Sorter)
[('Yana', 'Anja', 10, 0),
('Kolia', 'Alexey', 10, 0),
('Vasia', 'Katia', 3, 0),
('Petia', 'Anja', 3, 0),
('Petia', 'Katia', 3, 0)]
关于python - 如何对字符串和 int 值数组、按字母顺序和 "reversed"字母顺序的多个属性进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51293341/