RPA手把手:【Intermediate Python】四、Map,Filter 和 Reduce

324 篇文章 27 订阅
131 篇文章 9 订阅

艺赛旗 RPA10.0全新首发免费下载 点击下载

www.i-search.com.cn/index.html?from=line1

Map,Filter 和 Reduce 三个函数能为函数式编程提供便利。我们会通过实例一个一个讨论并理解它们。

Map
Map 会将一个函数应用到一个输入列表的所有元素上。这是它的规范:

map(function_to_apply, list_of_inputs)
大多数时候,我们要把列表中所有元素一个个地传递给一个函数,并收集输出。比方说:

items = [1, 2, 3, 4, 5]
squared = []
for i in items:
squared.append(i**2)
Map 可以让我们用一种简单且漂亮得多的方式来实现。就是这样:

items = [1, 2, 3, 4, 5]
squared = list(map(lambda x: x**2, items))
大多数时候,我们使用匿名函数(lambda)来配合 map,就像上面我们的做法。另外,不仅仅是一个普通列表,我们甚至可以用于一个元素全是函数的列表!

def multiply(x):
return x * x

def add(x):
return x + x

funcs = [multiply, add]
for i in range(5):
value = map(lambda x: x(i), funcs)
print(list(value))

Output:

[0, 0]

[1, 2]

[4, 4]

[9, 6]

[16, 8]

Filter
顾名思义,filter 过滤列表中的元素,并且返回一个由所有符合要求的元素所构成的列表,符合要求即函数作用到该元素时返回值为 True,下面是一个简短的例子:

number_list = range(-5, 5)
less_than_zero = filter(lambda x: x < 0, number_list)
print(list(less_than_zero))

Output: [-5, -4, -3, -2, -1]

这个 filter 类似于一个 for 循环,但它是一个内置函数,并且更快。

Reduce
当需要对一个列表进行一些计算并返回结果时,Reduce 是个非常有用的函数。举个例子,当你需要计算一个整数列表的乘积时。

通常在 python 中你可能会使用基本的 for 循环来完成这个任务。

现在我们来试试 reduce:

from functools import reduce
product = reduce(lambda x, y: x * y, [1, 2, 3, 4])

Output: 24

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值