如何对字符串和整数值,具有字母顺序和“反向”-字母顺序的多个属性的数组进行排序

时间:2018-07-11 19:57:14

标签: python string list sorting alphabetical-sort

我有一个包含[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)]

2 个答案:

答案 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)]
>>>