python 中的map() 、reduce() 和filter()函数

python中有几个比较有意思的函数map() 、reduce() 、filter()

1.map()

可以将一个序列(比如说列表)或可迭代对象的元素按照一个函数进行映射。

map对序列中的每个值都会调用我们传入的函数,得到映射以后的值,最终可以形成一个序列。

比如:

def f(a):
    return a*2

print(list(map(f,[1,2,3,4])))

#输出:[2, 4, 6, 8]

将列表中的元素映射成原来的两倍。当然,如果只是一些简单的映射的话,没必要单独写一个函数,我们可以使用lambda表达式(下面的例子中我都使用lambda表达式,如果不想用lambda的话可以换成对应的函数)。

比如:


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

#输出:[2, 4, 6, 8]

这里只是将f函数换成了对应的lambda表达式,效果是一样的。

 

2.reduce()

可以将一个序列或可迭代对象的元素按照一个函数(这个函数要接收两个参数)进行归并,最终得到一个值。

reduce首先会将序列中前两个元素带入我们传入的函数,得到一个值,然后对于剩下的每个元素都会和上一次的运算结果一起再次调用我们传入的函数,得到一个新值。一直这样,直到最后得到的是一个值。

(使用的时候要从functools模块中导入)

比如:

from functools import reduce

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

#输出:45

上面代码的功能就是求序列中所以元素的和。

为了方便大家理解,附上一张运算过程的图:

3.filter()

filter可以按照一个函数对序列或可迭代对象中的元素进行筛选。filter对于序列中的每个元素都会调用我们传入的函数,并且只会保留使函数的返回值为True的元素(筛选)。

如:


print(list(filter(lambda x:x>10,[1,2,23,453,11,3,4,5])))

#输出:[23, 453, 11]

筛选出列表中大于10的元素。

 

 

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值