首页 > 其他 > 详细

map/reduce

时间:2016-06-02 07:22:05      阅读:258      评论:0      收藏:0      [点我收藏+]
t = list(map(str, [1, 2, 3, 4, 5, 6, 7, 8, 9]))
print(t)

t = (x * x for x in range(10))
print(t)
for value in t:
    print(value)
from collections import Iterator
t2 = isinstance(t, Iterator)
print(t2)

reduce把一个函数作用在一个序列[x1, x2, x3, ...]上,这个函数必须接收两个参数,reduce把结果继续和序列的下一个元素做累积计算,其效果就是:

reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)

比方说对一个序列求和,就可以用reduce实现:

>>> from functools import reduce
>>> def add(x, y):
...     return x + y
...
>>> reduce(add, [1, 3, 5, 7, 9])
25

当然求和运算可以直接用Python内建函数sum(),没必要动用reduce

但是如果要把序列[1, 3, 5, 7, 9]变换成整数13579reduce就可以派上用场:

>>> from functools import reduce
>>> def fn(x, y):
...     return x * 10 + y
...
>>> reduce(fn, [1, 3, 5, 7, 9])
13579

map/reduce

原文:http://www.cnblogs.com/rain-1/p/5551699.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!