摘要:在本文中,您将学习Python中的三个令人印象粗浅的函数,即map(),filter和reduce()。
本文分享自华为云社区《从零开始学python | 应用Python映射,过滤和缩减函数:所有您须要晓得的》,原文作者:Yuchuan。
Python提供了许多预约义的内置函数,最终用户能够通过调用它们来应用它们。这些性能不仅简化了程序员的工作,而且创立了规范的编码环境。在本文中,您将学习Python中的三个令人印象粗浅的函数,即map(),filter和reduce()。
在持续之前,让咱们看一下内容:
- 什么是Python中的map,filter和reduce函数?
- 在以下范畴内应用用户定义的函数和lambda函数:
- map()函数
- filter()函数
- reduce()函数
- 一起应用map(),filter()和reduce()函数
- map()中的filter()
- filter()中的map()
- map()和filter()中带有reduce()
因而,让咱们开始吧。:)
什么是Python中的map(),filter()和reduce()函数?
如前所述,map(),filter()和reduce()是Python的内置函数。这些性能启用了Python的性能编程方面。在函数式编程中,传递的参数是决定输入的惟一因素。这些性能能够将任何其余性能用作参数,也能够提供给其余性能作为参数。当初让咱们更深刻地钻研这些性能。
map()函数:
map()函数是一种高阶函数。如前所述,此函数将另一个函数与一个可迭代序列一起作为参数,并在将该函数利用于序列中存在的每个可迭代序列之后返回输入。其语法如下:
句法:
地图(函数,可迭代)
在此,函数定义了一个表达式,该表达式又利用于可迭代对象。map函数能够将用户定义的函数以及lambda函数作为参数。
在以下范畴内应用用户定义的函数和Lambda函数:
map()中的用户定义函数:
map()函数能够将用户定义的函数作为参数。这些性能的参数由用户或程序员专门设置。例如:
例子:
def newfunc(a): return a*ax = map(newfunc, (1,2,3,4)) #x is the map objectprint(x)print(set(x))
输入:
<位于0x00000284B9AEADD8的地图对象>{16, 1, 4, 9}
如您所见,x是一个地图对象。下一部分输入显示以newfunc()作为参数的map函数,而后将a * a利用于所有可迭代对象。后果,所有可迭代变量的值将本身相乘并返回。
留神:输入不是按可迭代的值的程序,因为我应用过set()函数。您还能够应用list()或tuple()函数,例如:
例子:
def newfunc(a): return a*ax = map(newfunc, (1,2,3,4)) #x is the map objectprint(x)print(list(x))
输入:
<位于0x00000284B9AEA940的地图对象>[1, 4, 9, 16]
您还能够传递多个参数列表。例如:
例子:
def func(a, b): return a + b a = map(func, [2, 4, 5], [1,2,3])print(a)print(tuple(a))
输入:
<位于0x00000284B9BA1E80的地图对象>(3, 6, 8)
当初让咱们看看如何在map()函数中应用lambda函数。
map()中的Lambda函数:
Lambda函数是具备任何名称的函数。这些性能通常作为参数提供给其余性能。当初让咱们尝试将lambda函数嵌入map()函数中。思考以下示例:
例子:
tup= (5, 7, 22, 97, 54, 62, 77, 23, 73, 61)newtuple = tuple(map(lambda x: x+3 , tup)) print(newtuple)
输入:
(8, 10, 25, 100, 57, 65, 80, 26, 76, 64)
下面的输入是将lambda表达式(x + 3)利用于元组中存在的每个我的项目的后果。
filter()函数:
filter()函数用于创立由值组成的输入列表,该值针对该值返回true。它的语法如下:
句法:
过滤器(函数,可迭代)
就像map()一样,能够应用此函数,也能够将用户定义的函数以及lambda函数用作参数。
例子:
def func(x): if x>=3: return xy = filter(func, (1,2,3,4)) print(y)print(list(y))
输入:
<位于0x00000284B9BBCC50的过滤器对象>[3, 4]
如您所见,y是过滤器对象,并且列表是条件(x> = 3)正确的值的列表。
在filter()中应用lambda:
用作参数的lambda函数实际上定义了要查看的条件。例如:
例子:
y = filter(lambda x: (x>=3), (1,2,3,4))print(list(y))
输入:
[3,4]
下面的代码产生的输入与以前的函数雷同。
reduce()函数:
顾名思义,reduce()函数将给定函数利用于可迭代对象并返回单个值。
该函数的语法如下:
句法:
缩小(函数,可迭代)
此处的函数定义了须要将哪些表达式利用于可迭代对象。此性能须要从functools模块导入。例如:
例子:
from functools import reducereduce(lambda a,b: a+b,[23,21,45,98])
输入: 187
在下面的示例中,reduce函数间断增加列表中存在的每个可迭代对象,并返回单个输入。
Python中的map(),filter()和reduce()函数能够一起应用。
一起应用map(),filter()和reduce()函数:
执行此操作时,首先会解析外部函数,而后内部函数将对外部函数的输入进行操作。
让咱们首先尝试将filter()函数作为参数传递给map()函数。
在map()中应用filter():
上面给出的代码首先查看条件(x> = 3)对于可迭代对象是否为真。而后,应用map()函数映射输入。
例子:
c = map(lambda x:x+x,filter(lambda x: (x>=3), (1,2,3,4)))print(list(c))
输入: [6,8]
如果从给定的元组中滤除大于或等于3的整数,则后果为[3,4]。而后,如果应用(x + x)条件映射此条件,则将取得[6,8],即输入。
在filter()中应用map():
当您在filter()函数中应用map()函数时,可迭代对象首先由map函数进行操作,而后将filter()的条件利用于它们。
例子:
c = filter(lambda x: (x>=3),map(lambda x:x+x, (1,2,3,4))) #lambda x: (x>=3)print(list(c))
输入: [ 4、6、8 ]
在reduce()中应用map()和filter():
外部函数的输入依据提供给reduce()函数的条件而缩小。
例子:
d = reduce(lambda x,y: x+y,map(lambda x:x+x,filter(lambda x: (x>=3), (1,2,3,4)))) print(d)
输入: 14
输入是[6,8]的后果,它是外部map()和filter()函数的后果。
到此为止,咱们曾经完结了无关map(),filter()和Python中的reduce函数的文章的结尾。心愿您曾经分明地理解了所有内容。确保尽可能多地练习并复原教训。
点击关注,第一工夫理解华为云陈腐技术~