标签:
sorted
>>> help(sorted) Help on built-in function sorted in module __builtin__: sorted(...) sorted(iterable, cmp=None, key=None, reverse=False) --> new sorted list
list.sort
>>> help(list.sort) Help on method_descriptor: sort(...) L.sort(cmp=None, key=None, reverse=False) -- stable sort *IN PLACE*; cmp(x, y) -> -1, 0, 1
注:一般来说,cmp和key可以使用lambda表达式。
>>> print sorted([5, 2, 3, 1, 4]) [1, 2, 3, 4, 5]>>> L = [5, 2, 3, 1, 4] >>> L.sort() >>> print L [1, 2, 3, 4, 5]
>>>L = [(‘b‘,2),(‘a‘,1),(‘c‘,3),(‘d‘,4)] >>>print sorted (L, cmp=lambda x,y:cmp(x[1],y[1])) [(‘a‘, 1), (‘b‘, 2), (‘c‘, 3), (‘d‘, 4)]
>>>L = [(‘b‘,2),(‘a‘,1),(‘c‘,3),(‘d‘,4)] >>>print sorted (L, key=lambda x:x[1])) [(‘a‘, 1), (‘b‘, 2), (‘c‘, 3), (‘d‘, 4)]
>>> print sorted([5, 2, 3, 1, 4], reverse=True) [5, 4, 3, 2, 1] >>> print sorted([5, 2, 3, 1, 4], reverse=False) [1, 2, 3, 4, 5]
注:效率key>cmp(key比cmp快)
在Sorting Keys中:我们看到,此时排序过的L是仅仅按照第二个关键字来排的,如果我们想用第二个关键字
排过序后再用第一个关键字进行排序呢?
>>> L = [(‘d‘,2),(‘a‘,4),(‘b‘,3),(‘c‘,2)] >>> print sorted(L, key=lambda x:(x[1],x[0])) >>>[(‘c‘, 2), (‘d‘, 2), (‘b‘, 3), (‘a‘, 4)]
Python内置函数sorted()以及list.sort()
标签:
原文地址:http://my.oschina.net/u/1020238/blog/486670