sort的常用方法你一定都会了,但是如果要排序的对象的每个元素又含有多个元素,要按指定的内部某个元素排序该怎么实现呢?正常是这样来做的:
>>> def return_item(item):
... return item[1]
>>> pairs = [(1, 'one'), (2, 'two'), (3, 'three'), (4, 'four')]
>>> pairs.sort(key=return_item)
如果这样做,那就要多定义一个函数,是不是感觉很low,那么就使用lambda吧!
lambda是用来创建简单逻辑函数的一个优雅的方法,例如:
>>> def make_incrementor(n):
... return lambda x: x + n
...
>>> f = make_incrementor(42)
>>> f(0)
42
>>> f(1)
43
搭配sort的效果是这样的:
>>> pairs = [(1, 'one'), (2, 'two'), (3, 'three'), (4, 'four')]
>>> pairs.sort(key=lambda pair: pair[1])
>>> pairs
[(4, 'four'), (1, 'one'), (3, 'three'), (2, 'two')]
如果按两个元素排序,是这样的:
>>> pairs = [(1, 'one'), (2, 'two'), (3, 'three'), (4, 'four')]
>>> pairs.sort(key=lambda pair: (pair[0], pair[1]))
>>> pairs
[(1, 'one'), (2, 'two'), (3, 'three'), (4, 'four')]
快去试一试吧!!!