码迷,mamicode.com
首页 > 其他好文 > 详细

map/reduce

时间:2016-06-02 07:23:32      阅读:114      评论: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
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!