[英]Python - order list of lists by multiple column indexes
假设我在Python中有以下列表x
[['a',6,'aa']
['d',7,'bb']]
['c',1,'cc']
['a',4,'dd']
['d',2,'ee']]
我想对其元素进行排序以获得以下结果
[['a',4,'dd']
['a',6,'aa']
['c',1,'cc']
['d',2,'ee']
['d',7,'bb']]
那就是我想按两列对其进行排序,第一列(最重要)和第二列(次重要)。 这可能是一个重复的问题,但我无法找到解决方案...
以下按第一个元素,然后按第二个元素对列表进行排序:
>>> sorted(a, key=lambda x:(x[0], x[1]))
[['a', 4, 'dd'], ['a', 6, 'aa'], ['c', 1, 'cc'], ['d', 2, 'ee'], ['d', 7, 'bb']]
由于是否也按第三列进行排序都无关紧要,因此可以在此处使用普通sort
并获得相同的结果:
>>> sorted(a)
[['a', 4, 'dd'], ['a', 6, 'aa'], ['c', 1, 'cc'], ['d', 2, 'ee'], ['d', 7, 'bb']]
这是因为列表从左到右进行比较,并按字典顺序排序。
如果确实要按任意列顺序进行排序,则应使用operator.itemgetter
,这比对key
使用lambda
函数要快。
>>> import operator
>>> sorted(a, key=operator.itemgetter(1, 0)) # order by column 1 first, then 0.
[['c', 1, 'cc'], ['d', 2, 'ee'], ['a', 4, 'dd'], ['a', 6, 'aa'], ['d', 7, 'bb']]
如果从第一个元素到最后一个元素应用排序,则可以简单地使用sorted
作为sorted
自动句柄。
a = [['a',6,'aa'],['d',7,'bb'],['c',1,'cc'],['a',4,'dd'],['d',2,'ee']]
sorted(a)
[['a', 4, 'dd'],
['a', 6, 'aa'],
['c', 1, 'cc'],
['d', 2, 'ee'],
['d', 7, 'bb']]
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.