python中有三个函数式编程极大的简化了程序的复杂性,这里就做一下讨论和记录。
一 Map:应用在链表输入所有元素的函数,它的格式如下所示:
map(function_to_apply, list_of_inputs)
大多数情况下,我们会把一个链表中的元素一个个输入到函数中来获取结果,代码如下所示:
items = [1, 2, 3, 4, 5] squared = [] for i in items: squared.append(i**2)
map就可以把这个函数简化,如下所示:
items = [1, 2, 3, 4, 5] squared = list(map(lambda x: x**2, items))
大多数情况下,我们把 lambda结合map一起使用,替代传统的输入,如下所示:
def multiply(x): return (x*x) def add(x): return (x+x) funcs = [multiply, add] for i in range(5): value = list(map(lambda x: x(i), funcs)) print(value) # Output: # [0, 0] # [1, 2] # [4, 4] # [9, 6] # [16, 8]
二 Filter:创建一个让函数返回为True的链表元素,下面是一个简洁的例子:
number_list = range(-5,5) less_than_zero = list(filter(lambda x: x < 0, number_list)) print(less_than_zero) number_list = range(-5,5) less_than_zero = list(filter(lambda x: x != 0, number_list)) print(less_than_zero)
三 reduce:在链表元素的循环计算方面有着广泛的用途,
正常情况下,计算的是这样写的:
product = 1 list = [1, 2, 3, 4] for num in list: product = product * num # product = 24
在使用reduce的情况下,是这样计算的:
from functools import reduce product = reduce((lambda x, y: x * y), [1, 2, 3, 4]) # Output: 24
一下子简洁了很多。
参考文档:
1 http://book.pythontips.com/en/latest/map_filter.html