参考:《流畅的python》
在python中,接受函数为参数,或者把函数作为结果返回的函数是高阶函数(higher-order function),其中,map就是高阶函数。内置函数sorted也是:可选的key参数用于提供一个函数,他会应用到各个元素上进行排序。
例如想给水果按照单词长度排序。
另外,例如想根据单词反过来的顺序然后排序。
map filter reduce替代品
首先定义一个求阶乘的函数。
def factorial(n):
return 1 if n < 2 else n * factorial(n - 1)
print(factorial(42))
fac = factorial
print(fac(5))
在python3中,map和filter还是内置函数,但是由于引入了列表推倒和生成器表达式,他们变得没有那么重要了。如下面所示。
print(list(map(fac, range(6))))
print([fac(n) for n in range(6)])
filter也可以用if进行替换,下面计算奇数的阶乘。
print(list(map(fac, filter(lambda n : n % 2, range(6)))))
print([fac(n) for n in range(6) if n % 2])
在 Python 2 中,reduce 是内置函数,但是在 Python 3 中放到 functools 模块里了。这个函数最常用于求和
Python 2.3 开始,最好使用内置的 sum 函数。在可读性和性能方面,这 是一项重大改善