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')]
快去试一试吧!!!
本文介绍如何使用Python的lambda表达式进行高效排序,包括单一元素和复合元素的排序方法,通过实例展示lambda在sort函数中的应用。
5843

被折叠的 条评论
为什么被折叠?



