filter, map和reduce在python2中完美地工作。这里有一个例子:
>>> def f(x):
return x % 2 != 0 and x % 3 != 0
>>> filter(f, range(2, 25))
[5, 7, 11, 13, 17, 19, 23]
>>> def cube(x):
return x*x*x
>>> map(cube, range(1, 11))
[1, 8, 27, 64, 125, 216, 343, 512, 729, 1000]
>>> def add(x,y):
return x+y
>>> reduce(add, range(1, 11))
55
但在Python 3中,我收到以下输出:
>>> filter(f, range(2, 25))
<filter object at 0x0000000002C14908>
>>> map(cube, range(1, 11))
<map object at 0x0000000002C82B70>
>>> reduce(add, range(1, 11))
Traceback (most recent call last):
File "<pyshell#8>", line 1, in <module>
reduce(add, range(1, 11))
NameError: name 'reduce' is not defined
如果有人能给我解释一下这是为什么,我会很感激。
为进一步清晰起见,代码截图如下:
下面是Filter, map和reduce函数的例子。
数量=(10、11、12,22岁,34岁,43岁,54岁,34岁,67年,87年,88年,98年,99年,87年,44岁,66年)
/ /过滤
oddNumbers = list(lambda x: x%2 != 0, numbers))
打印(oddNumbers)
/ /地图
multiplyOf2 = list(map(lambda x: x*2, numbers))
打印(multiplyOf2)
/ /减少
由于reduce函数不常用,因此已从Python 3的内置函数中删除。它仍然在functools模块中可用,所以你可以这样做:
从functools导入reduce
sumOfNumbers = reduce(lambda x,y: x+y, numbers)
打印(sumOfNumbers)
映射、过滤和还原的优点之一是,当你把它们“链接”在一起做一些复杂的事情时,它们变得多么容易读懂。但是,内置语法不清晰,而且都是“向后”的。因此,我建议使用PyFunctional包(https://pypi.org/project/PyFunctional/)。
以下是两者的对比:
flight_destinations_dict = {'NY': {'London', 'Rome'}, 'Berlin': {'NY'}}
PyFunctional版本
非常清晰的语法。你可以说:
“我有一系列的航班目的地。我想从中脱身
如果city在dict值中,则为dict键。最后,过滤掉
我在这个过程中创建的空列表。”
from functional import seq # PyFunctional package to allow easier syntax
def find_return_flights_PYFUNCTIONAL_SYNTAX(city, flight_destinations_dict):
return seq(flight_destinations_dict.items()) \
.map(lambda x: x[0] if city in x[1] else []) \
.filter(lambda x: x != []) \
Python默认版本
这一切都是颠倒的。你需要说:
“好吧,这是一个列表。我想过滤掉空列表。为什么?
因为如果城市在dict值中,我首先得到dict键。
哦,我要做这个的列表是flight_destinations_dict
def find_return_flights_DEFAULT_SYNTAX(city, flight_destinations_dict):
return list(
filter(lambda x: x != [],
map(lambda x: x[0] if city in x[1] else [], flight_destinations_dict.items())
)
)