使用排序另一个列表的结果在Python中对列表进行排序

时间:2012-03-03 03:38:21

标签: python

我在Python中有两个列表

list_1 = [5, 2, 8];
list_2 = ['string1', 'string2', 'string3']

我想对第一个列表进行排序并使用结果对第二个列表进行排序。

换句话说,结果应该是:

# Sorted in descending order
list_1_sorted = [8, 5, 2];
list_2_sorted = ['string3', 'string1', 'string2'];

我知道如何单独对每个列表进行排序,但是我如何使用排序其他列表产生的索引排列来置换一个列表?

4 个答案:

答案 0 :(得分:19)

Schwartzian transform

list_1_sorted, list_2_sorted = zip(*sorted(zip(list_1, list_2),
  key=operator.itemgetter(0), reverse=True))

答案 1 :(得分:16)

将列表压缩在一起,排序,解压缩列表:

together = zip(list_1, list_2)
sorted_together =  sorted(together)

list_1_sorted = [x[0] for x in sorted_together]
list_2_sorted = [x[1] for x in sorted_together]

这里发生的是zip创建一个元组列表,其中您希望列表的元素是第一个元素排序:

>>> a = [1,3,7,3,2]
>>> b = ["one","two",'three','four','five']
>>> zip(a,b)
[(1, 'one'), (3, 'two'), (7, 'three'), (3, 'four'), (2, 'five')]

然后当你对它们进行排序时,它们的元素保持配对:

>>> sorted(zip(a,b))
[(1, 'one'), (2, 'five'), (3, 'four'), (3, 'two'), (7, 'three')]

然后剩下的就是解压缩这些列表。

答案 2 :(得分:3)

您可以使用zip

>>> list_1 = ['string1', 'string2', 'string3']
>>> list_2 = [5, 2, 8]
>>> s = sorted(zip(list_2, list_1), reverse=True)
>>> list_1_sorted = [e[1] for e in s]
>>> list_2_sorted = [e[0] for e in s]
>>> list_1_sorted
['string3', 'string1', 'string2']
>>> list_2_sorted
[8, 5, 2]
>>> 

答案 3 :(得分:2)

@ Ignacio的回答是最好的,但是如果你需要就地排序而不制作新的列表,你可以试试这个:

import itertools
list_enumerate = itertools.count()

list_2.sort(reverse=True, key=lambda k: list_1[next(list_enumerate)])
list_1.sort(reverse=True)
print list_1
print list_2

请注意我认为没有任何保证按顺序为每个列表项调用key函数(这是必要的),所以这是一个风险的使用方法。