【发布时间】:2011-05-09 15:56:47
【问题描述】:
我有一个列表列表。例如,
[
[0,1,'f'],
[4,2,'t'],
[9,4,'afsd']
]
如果我想通过内部列表的字符串字段对外部列表进行排序,你会如何在 python 中做到这一点?
【问题讨论】:
我有一个列表列表。例如,
[
[0,1,'f'],
[4,2,'t'],
[9,4,'afsd']
]
如果我想通过内部列表的字符串字段对外部列表进行排序,你会如何在 python 中做到这一点?
【问题讨论】:
使用自定义键功能,您可以轻松地根据需要对任何列表进行排序:
L = [[0,1,'f'], [4,2,'t'], [9,4,'afsd']]
def sorter(lst):
return lst[2].casefold()
L.sort(key=sorter)
# result: [[9, 4, 'afsd'], [0, 1, 'f'], [4, 2, 't']]
【讨论】:
确保在要排序的列表中没有任何 null 或 NaN 值。如果有 NaN 值,那么您的排序将被关闭,影响非空值的排序。
【讨论】:
对多维数组进行排序execute here
arr=[[2,1],[1,2],[3,5],[4,5],[3,1],[5,2],[3,8],[1,9],[1,3]]
arr.sort(key=lambda x:x[0])
la=set([i[0] for i in Points])
for i in la:
tempres=list()
for j in arr:
if j[0]==i:
tempres.append(j[1])
for j in sorted(tempres,reverse=True):
print(i,j)
【讨论】:
**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])**
如果我错了,请纠正我,但不是“x[2]”调用列表中的第 3 项,而不是嵌套列表中的第 3 项?应该是 x[2][2] 吗?
【讨论】:
更容易理解(Lambda 实际在做什么):
ls2=[[0,1,'f'],[4,2,'t'],[9,4,'afsd']]
def thirdItem(ls):
#return the third item of the list
return ls[2]
#Sort according to what the thirdItem function return
ls2.sort(key=thirdItem)
【讨论】:
array.sort(key = lambda x:x[1])
您可以使用这个 sn-p 轻松排序,其中 1 是元素的索引。
【讨论】:
我认为 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']]
【讨论】:
多个条件也可以通过lambda函数实现
sorted_list = sorted(list_to_sort, key=lambda x: (x[1], x[0]))
【讨论】:
Itemgetter 允许您按多个条件/列进行排序:
sorted_list = sorted(list_to_sort, key=itemgetter(2,0,1))
【讨论】:
这是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']]
这里也可以使用 lambda 函数,但是在这个简单的例子中 lambda 函数比较慢
【讨论】:
key=lambda x:x[2].casefold()。如果您的 Python 不够新,只需使用 .lower() 而不是 .casefold()
到位
>>> l = [[0, 1, 'f'], [4, 2, 't'], [9, 4, 'afsd']]
>>> l.sort(key=lambda x: x[2])
未使用 sorted:
>>> sorted(l, key=lambda x: x[2])
【讨论】:
in place 和not in place 的详细信息?
l.sort(key=lambda x: x[2], reverse=True)
像这样:
import operator
l = [...]
sorted_list = sorted(l, key=operator.itemgetter(desired_item_index))
【讨论】: