一文弄懂Python中的Map、Filter和Reduce函数

1. 引言

本文重点介绍Python中的三个特殊函数Map,Filter和Reduce,以及如何使用它们进行代码编程。在开始介绍之前,我们先来理解两个简单的概念高阶函数和Lambda函数。
闲话少说,我们直接开始吧!

2. 高阶函数

把函数作为参数传入,这样的函数称为高阶函数,函数式编程就是指这种高度抽象的编程范式。
举例如下:

def higher(your_function, some_variable):
    return your_function(some_variable)

实质上,函数map,filter和reduce均为高阶函数,它们的输入参数为函数和可迭代对象(list,tuple等),具体形式如下:

map(your_function, your_list)
filter(your_function, your_list)
reduce(your_function, your_list)

3. Lambda表达式

Lambda 函数类似于普通的 Python 函数,区别在于我们必须为普通函数命名,但对于 lambda 函数,它是可选的。具体语法如下:

lambda inputs: output

接下来,让我们看一下几个普通函数及其 lambda 函数等效实现,如下:

def multiply2(x):           # is the same as
    return x * 2
multiply2 = lambda x: x*2   # lambda function

另一个例子如下:

def add(a, b):          # is the same as
    return a + b
add = lambda a,b: a+b   # lambda function

4. Map函数

Map 用于迭代可可迭代对象中的每个元素进行相应的转换操作。
例如,通过将 [1,2,3] 中的每个元素乘以 2,将 [1,2,3] 变换为 [2,4,6]
为此,我们需要一个lambda函数,该函数用于实现将单个元素乘2的操作,如下:

before = [1,2,3]
after = list(map(lambda x:x*2, before))
# after is [2,4,6]

此外,我们在看下个示例,主要用于将字符串所有字符转换为大写形式。如下:

before = ["apple", "orange", "pear"]
after = list(map(lambda x:x.upper(), before))
# after is ["APPLE", "ORANGE", "PEAR"]

需要注意的是,虽然上述 lambda 函数中使用变量 x,但只要它是有效的变量名称,我们可以更换为任何我们想要取的变量名称。

5. Filter函数

函数Filter主要功能为对于根据特定过滤条件来从可迭代对象中的选择相应的元素。举例,对于列表[1,2,3,4,5,6],如果我们想要过滤得到其中的奇数数元素。我们可以实现一个lambda函数,当参数为奇数时为True,否则为False。

代码如下:

before = [1,2,3,4,5,6]
after = list(filter(lambda x:x%2==1, before))
# after is [1,3,5]

在举个栗子,实现只保留字符串长度大于等于5的,即将列表[“apple”,“orange”,“pear”]转换为[“apple”,“orange”]。此时我们可以实现一个lambda函数,接收一个字符串,如果该字符串的长度大于等于5,则返回True,否则为False。
代码如下:

before = ["apple", "orange", "pear"]
after = list(filter(lambda x:len(x)>=5, before))
# after is ["apple", "orange"]

6. Reduce函数

函数Reduce主要用于以某种方式来组合可迭代对象中的所有元素。
与函数mapfilter不同,我们需要单独引入 reduce,如下所示:

 from functools import reduce

此外,reduce中使用的lambda函数需要两个参数,它主要用于告诉我们如何将两个元素组合成起来。举个栗子,假如我们需要将列表[1,2,3,4,5]中的所有元素进行相乘得到数字120,这里我们需要实现的lambda函数就是接收两个数字,并将他们相乘。
代码示例如下:

from functools import reduce
before = [1,2,3,4,5]
after = reduce(lambda a,b: a*b, before)
# after is 120

另外一个例子,如果我们需要使用-来将字符串连接起来。具体为将列表["apple", "orange", "pear"]变成"apple-orange-pear"。这里,我们需要实现一个lambda函数,它接受2个字符串,并将它们用一个-字符相加。
代码实现如下:

from functools import reduce
before = ["apple", "orange", "pear"]
after = reduce(lambda a,b: a+"-"+b, before)

7. 总结

本文从高级函数和Lambda函数入手,先后介绍了Map,Filter和Reduce三个高级函数的用法,并给出了相应的代码示例。

您学废了嘛?

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

赵卓不凡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值