如何按任意函数描述的键对列表进行排序?例如,如果我有:
mylist = [["quux", 1, "a"], ["bar", 0, "b"]]
我想用每个成员的第二个元素对“mylist”进行排序,例如
sort(mylist, key=lambda x: x[1])
我该怎么做?
答案 0 :(得分:46)
你基本上已经拥有它了:
>>> mylist = [["quux", 1, "a"], ["bar", 0, "b"]]
>>> mylist.sort(key=lambda x: x[1])
>>> print mylist
给出:
[['bar', 0, 'b'], ['quux', 1, 'a']]
这将对mylist进行排序。
[本段编辑感谢@ Daniel的更正。] sorted
将返回一个新的列表,该列表已排序而非实际更改输入,如http://wiki.python.org/moin/HowTo/Sorting/中所述。
答案 1 :(得分:9)
你有两个选择,非常接近你所描述的,实际上:
mylist.sort(key=lambda x: x[1]) # In place sort
new_list = sorted(mylist, key=lambda x: x[1])
答案 2 :(得分:9)
这是一种常见的需求,它的支持已经以operator.itemgetter
的形式添加到标准库中:
from operator import itemgetter
mylist = [["quux", 1, "a"], ["bar", 0, "b"]]
mylist.sort(key=itemgetter(1)) # or sorted(mylist, key=...)
答案 3 :(得分:5)
Sort和itemgetter是最快的。
>>> import operator
>>> import timeit
>>> mylist = [["quux", 1, "a"], ["bar", 0, "b"]]
>>> t1 = timeit.Timer(lambda: mylist.sort(key=lambda x: x[1]))
>>> t1.timeit()
1.6330803055632404
>>> t2 = timeit.Timer(lambda: mylist.sort(key=operator.itemgetter(1)))
>>> t2.timeit()
1.3985503043467773
>>> t3 = timeit.Timer(lambda: sorted(mylist, key=operator.itemgetter(1)))
>>> t3.timeit()
2.6329514733833292
>>> t4 = timeit.Timer(lambda: sorted(mylist, key=lambda x: x[1]))
>>> t4.timeit()
2.9197154810598533
答案 4 :(得分:4)
答案是使用“已排序”,即
sorted(mylist, key=lambda x: x[1])
答案 5 :(得分:0)
您的问题的解决方案是:
sorted_list = sorted(mylist, key=lambda value:value[1])
列表字典的解决方案是:
mylist = [{'name':'kk', 'age':21},{'name':'bk', 'age':21}]
sorted_list = sorted(mylist, key=lambda k: k['key_name'])