排序2D列表python

时间:2013-09-01 22:45:07

标签: python sorting

我有以下类型的列表

[1, 0.23]
[2, 0.39]
[4, 0.31]
[5, 0.27]

我想按第二列的降序排序。我在python中试过'sorted'函数。但是给我一个'TypeError':'float'对象是unsubscriptable。 请帮我解决这个问题。

2 个答案:

答案 0 :(得分:28)

您可以使用lambda:

>>> li=[[1, 0.23],
... [2, 0.39],
... [4, 0.31],
... [5, 0.27]]
>>> sorted(li,key=lambda l:l[1], reverse=True)
[[2, 0.39], [4, 0.31], [5, 0.27], [1, 0.23]]

或者另一种方式:

>>> sorted(li,key=lambda l:l[1])
[[1, 0.23], [5, 0.27], [4, 0.31], [2, 0.39]]

答案 1 :(得分:13)

要对第二列上的列表列表进行排序,请使用operator.itemgetter()以方便和清晰:

from operator import itemgetter
outputlist = sorted(inputlist, key=itemgetter(1), reverse=True)

或者,就地排序:

from operator import itemgetter
inputlist.sort(key=itemgetter(1), reverse=True)

itemgetter()比使用lambda执行任务要快一些。

演示:

>>> from operator import itemgetter
>>> inputlist = [
...     [1, 0.23],
...     [2, 0.39],
...     [4, 0.31],
...     [5, 0.27],
... ]
>>> sorted(inputlist, key=itemgetter(1), reverse=True)
[[2, 0.39], [4, 0.31], [5, 0.27], [1, 0.23]]

如果您的输入列表中的浮点值直接,您只会看到异常:

>>> inputlist.append(4.2)
>>> inputlist
[[1, 0.23], [2, 0.39], [4, 0.31], [5, 0.27], 4.2]
>>> sorted(inputlist, key=itemgetter(1), reverse=True)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: 'float' object is not subscriptable

(对于Python 3; Python 2的错误消息略有不同,导致TypeError: 'float' object has no attribute '__getitem__')。

这是因为itergetter(1)调用应用于外部列表中的所有元素,但仅适用于嵌套的有序序列,而不适用于现在添加的一个浮点值。