python中的map、filter、reduce函数

三个函数比较相似,都是应用于序列的内置函数。常见的序列包括list、tuple、str。ide

1.map函数函数

map函数会根据提供的函数对指定序列作映射。ip

map函数的定义:string

map(function, sequence[, sequence, ...]) -> listit

经过定义能够看到,这个函数的第一个参数是一个函数,剩下的参数是一个或多个序列,返回值是一个集合。io

function能够理解为是一个一对一或多对一函数,map的做用是以参数序列中的每个元素调用function函数,返回包含每次function函数返回值的list。function

好比要对一个序列中的每一个元素进行平方运算:class

map(lambda x: x ** 2, [1, 2, 3, 4, 5])lambda

返回结果为:map

[1, 4, 9, 16, 25]

在参数存在多个序列时,会依次以每一个序列中相同位置的元素作参数调用function函数。

好比要对两个序列中的元素依次求和。

map(lambda x, y: x + y, [1, 3, 5, 7, 9], [2, 4, 6, 8, 10])

map返回的list中第一个元素为,参数序列1的第一个元素加参数序列2中的第一个元素(1 + 2),

list中的第二个元素为,参数序列1中的第二个元素加参数序列2中的第二个元素(3 + 4),

依次类推,最后的返回结果为:

[3, 7, 11, 15, 19]

要注意function函数的参数数量,要和map中提供的集合数量相匹配。

若是集合长度不相等,会以最小长度对全部集合进行截取。

当函数为None时,操做和zip类似:

map(None, [1, 3, 5, 7, 9], [2, 4, 6, 8, 10])

返回结果为:

[(1, 2), (3, 4), (5, 6), (7, 8), (9, 10)]

2.filter函数

filter函数会对指定序列执行过滤操做。

filter函数的定义:

filter(function or None, sequence) -> list, tuple, or string

function是一个谓词函数,接受一个参数,返回布尔值True或False。

filter函数会对序列参数sequence中的每一个元素调用function函数,最后返回的结果包含调用结果为True的元素。

返回值的类型和参数sequence的类型相同

好比返回序列中的全部偶数:

def is_even(x):

return x & 1 != 0

filter(is_even, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10])

返回结果为:

[1, 3, 5, 7, 9]

若是function参数为None,返回结果和sequence参数相同。

3.reduce函数

reduce函数,reduce函数会对参数序列中元素进行累积。

reduce函数的定义:

reduce(function, sequence[, initial]) -> value

function参数是一个有两个参数的函数,reduce依次从sequence中取一个元素,和上一次调用function的结果作参数再次调用function。

第一次调用function时,若是提供initial参数,会以sequence中的第一个元素和initial做为参数调用function,不然会以序列sequence中的前两个元素作参数调用function。

reduce(lambda x, y: x + y, [2, 3, 4, 5, 6], 1)

结果为21(  (((((1+2)+3)+4)+5)+6)  )

reduce(lambda x, y: x + y, [2, 3, 4, 5, 6])

结果为20

注意function函数不能为None。

相关文章
相关标签/搜索