如何按内部列表的特定索引对列表列表进行排序?

old*_*ice 210 python sorting

我有一份清单清单.例如,

[
[0,1,'f'],
[4,2,'t'],
[9,4,'afsd']
]
Run Code Online (Sandbox Code Playgroud)

如果我想通过内部列表的字符串字段对外部列表进行排序,那么如何在python中执行此操作?

Joh*_*ooy 294

这是itemgetter的工作

>>> from operator import itemgetter
>>> L=[[0, 1, 'f'], [4, 2, 't'], [9, 4, 'afsd']]
>>> sorted(L, key=itemgetter(2))
[[9, 4, 'afsd'], [0, 1, 'f'], [4, 2, 't']]
Run Code Online (Sandbox Code Playgroud)

这里也可以使用lambda函数,但在这种简单的情况下lambda函数较慢

  • @bzupnick,使用`key = lambda x:x [2] .casefold()`.如果你的Python不够新,只需使用`.lower()`而不是`.casefold()` (5认同)

mou*_*uad 154

到位

>>> l = [[0, 1, 'f'], [4, 2, 't'], [9, 4, 'afsd']]
>>> l.sort(key=lambda x: x[2])
Run Code Online (Sandbox Code Playgroud)

没有使用排序的地方:

>>> sorted(l, key=lambda x: x[2])
Run Code Online (Sandbox Code Playgroud)

  • @qun,"就地"意味着旧列表的内存被重新用于已排序的内存."not in place"表示旧列表保持不变并创建新列表. (7认同)
  • 你能提供一些关于"就地"和"不到位"的更多细节吗? (3认同)
  • 对于降序:`l.sort(key=lambda x: x[2],verse=True)` (2认同)

fid*_*der 71

Itemgetter允许您按多个条件/列进行排序:

sorted_list = sorted(list_to_sort, key=itemgetter(2,0,1))
Run Code Online (Sandbox Code Playgroud)

  • 我认为这个答案非常重要.我认为尝试按内部数组索引排序的人会落在这里,但是想要按MULTIPLE内部数组索引排序的人将从这里开始,你的回答帮助我看到itemgetter实际上会为你做到这一点! (4认同)

Abh*_*bhi 9

array.sort(key = lambda x:x[1])
Run Code Online (Sandbox Code Playgroud)

您可以使用此代码段轻松进行排序,其中1是元素的索引。


Jim*_*som 8

像这样:

import operator
l = [...]
sorted_list = sorted(l, key=operator.itemgetter(desired_item_index))
Run Code Online (Sandbox Code Playgroud)


小智 8

多个标准也可以通过lambda函数实现

sorted_list = sorted(list_to_sort, key=lambda x: (x[1], x[0]))
Run Code Online (Sandbox Code Playgroud)


Tus*_*ras 7

我认为lambda函数可以解决你的问题.

old_list = [[0,1,'f'], [4,2,'t'],[9,4,'afsd']]

#let's assume we want to sort lists by last value ( old_list[2] )
new_list = sorted(old_list, key=lambda x: x[2])

#Resulst of new_list will be:

[[9, 4, 'afsd'], [0, 1, 'f'], [4, 2, 't']]
Run Code Online (Sandbox Code Playgroud)