python的映射_Python学习:映射函数(map)和函数式编程工具(filter和reduce)

在序列中映射函数map

map函数会对一个序列对象中的每一个元素应用被传入的函数,并且返回一个包含了所有函数调用结果的一个列表。

例1:def sum(x):

return x + 10

L1 = [1,2,3,4,5,6,7]

L = map(sum, L1)

#结果为[11, 12, 13, 14, 15, 16, 17]

map还有更高级的使用方法,例如提供了序列作为参数,它能够并行返回分别以每个序列中的元素作为函数对应参数得到的结果的列表。如例2所示。

例2:def sum(x, y):

return x + y

L1 = [1,2,3,4,5,6]

L2 = [10,11,12,13,14,15]

print map(sum, L1, L2)

#结果为[11, 13, 15, 17, 19, 21]

注意:map调用与列表解析很相似,但是map对每一个元素都应用了函数调用而不是任意的表达式。因为这点闲置,从某种意义上来说,它成为了一个不太通用的工具,尽管如此,在某些情况下,目前map比列表解析运行起来更快。它也比for循环更快。

函数式编程工具(filter和reduce)

map函数是Python用来进行函数式编程的这类工具中最简单的内置函数代表:函数式编程的意思就是对应序列应用一些函数的工具。例如,基于某一侧式函数过滤出一些元素(filter),以及对每对元素都应用函数并运行到最后结果(reduce)。由于range和filter都返回可迭代对象,在Python3.0中,它们需要list调用来显示其所有结果。

序列中的元素若其返回值为真的话,将会被键入到结果的列表中。就像map,这个函数能够用for 循环来等效,但是它是内置的,运行起来比较快。L = range(-10,10)

print filter(lambda x:x>4, L)

#结果为[5, 6, 7, 8, 9]

序列中的元素若其返回值为真的话,将会被键入到结果的列表中。就像map,这个函数能够用for 循环来等效,但是它是内置的,运行起来比较快。res = []

for x in range(-10,10):

if x >5:

res.append(x)

print(res)

#结果为[5, 6, 7, 8, 9]

reduce在Python2.6中只是一个简单的内置函数,但是在Python3.0中则位于functools模块中,要更复杂一些。>>>reduce((lambda x,y: x+y), [1,2,3,4,5])

15

>>>reduce((lambda x,y: x*y), [1,2,3,4,5])

120

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值