Python内建了map() reduce() filter()函数。

我们先看map。map()函数接收两个参数,一个是函数,一个是序列,map将传入的函数依次作用到序列的每个元素,并把结果作为新的list返回。

map即通过函数对列表进行处理得到新的列表。

>>> def cube(x):

...     return x * x 

... 

>>> map(cube,range(10))

[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]

再看reduce的用法。reduce把一个函数作用在一个序列[x1, x2, x3...]上,这个函数必须接收两个参数,reduce把结果继续和序列的下一个元素做累积计算。

reduce 通过函数会先接收初始值和序列的第一个元素,然后是返回值和下一个元素,依此类推。

>>> def add(x,y):

...     return x + y

... 

>>> reduce(add,range(10))

45

结果45,是0到9的和,x的值是上一次函数返回的结果,y是列表中循环的值。

>>> reduce(lambda x,y: x+y, range(10))

45

等同上面两条,lambda来创建匿名函数[ lambda x,y:x+y ] ,后面跟可迭代的对象。

filter即通过函数方法只保留结果为真的值组成列表。

>>> def f(n):

...     return n % 2 == 1

... 

>>> filter(f, range(10))

[1, 3, 5, 7, 9]