Map,Filter 和 Reduce

Map,Filter 和 Reduce 三个函数能为函数式编程提供便利。

#Map会将一个函数映射到一个输入列表的所有元素上,甚至可以用于一列表的函数。
items = [1,2,3,4,5]
squared = []
squared = map(lambda x: x**2, items)
print(list(squared))

def multiply(x):
    return (x*x)
def add(x):
    return (x + x)

funcs = [multiply, add]

for i in range(5):
    value = map(lambda x: x(i), funcs)
    print(list(value))

#顾名思义,filter过滤列表中的元素,并且返回一个由所有符合要求的元素所构成的列表,符合要求即函数映射到该元素时返回值为True.
#这个filter类似于一个for循环,但它是一个内置函数,并且更快。
number_list = range(-5, 5)
less_than_zero = filter(lambda x: x<0, number_list)
print(list(less_than_zero))

#当需要对一个列表进行一些计算并返回结果时,Reduce 是个非常有用的函数。
from functools import reduce
product = reduce((lambda x,y: x*y), [1,2,3,4])
print(product)

运行结果:

D:\python3.6.1\python.exe F:/python_Advanced/map_filter_reduce.py
[1, 4, 9, 16, 25]
[0, 0]
[1, 2]
[4, 4]
[9, 6]
[16, 8]
[-5, -4, -3, -2, -1]
24


Process finished with exit code 0


posted @ 2017-07-03 15:48  书灯  阅读(8)  评论(0)    收藏  举报  来源