python的map与reduce

Posted chen狗蛋儿

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python的map与reduce相关的知识,希望对你有一定的参考价值。

 

map(f, Itera)  # 对每一个元素都使用f(x)

 

>>> sq = lambda x:x**2
>>> l = map(sq,[-1,0,1,2,-3])
>>> list(l)
[1, 0, 1, 4, 9]

 

当然也可以传入两个参数的:

>>> add = lambda x, y: x + y
>>> l = map(lambda x, y: x + y, [1, 3, 5, 7, 9], [2, 4, 6, 8, 10])
>>> list(l)
[3, 7, 11, 15, 19]

 

 

 

reduce(f(x), Itera)   # 对前一个x1把结果f(x1)继续和序列的下一个元素x2做累积计算

函数f必须有两个参数x,y

 

>>> from functools import reduce
>>> def add(x,y): #定义一个相加函数
        return x+y

>>> reduce(add,[1,2,3,4,6])
16

 

add(x,y)是我们定义的一个函数,将add函数和[1,2,3,4,6]列表传入reduce函数,就相当于1+2+3+4+6 =16。即把结果继续和序列的下一个元素做累加。

 



以上是关于python的map与reduce的主要内容,如果未能解决你的问题,请参考以下文章

python的map与reduce

JavaScript 代码片段

Python入门之经典函数实例——第3关:Map-Reduce - 映射与归约的思想

Python入门之经典函数实例——第3关:Map-Reduce - 映射与归约的思想

map 与filter和reduce内置函数

python3中内建函数map()与reduce()的使用方法