Python的functools.reduce用法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python的functools.reduce用法相关的知识,希望对你有一定的参考价值。

python 3.0以后, reduce已经不在built-in function里了, 要用它就得from functools import reduce.

reduce的用法

reduce(function, sequence[, initial]) -> value

Apply a function of two arguments cumulatively to the items of a sequence,
from left to right, so as to reduce the sequence to a single value.
For example, reduce(lambda x, y: x+y, [1, 2, 3, 4, 5]) calculates
((((1+2)+3)+4)+5).  If initial is present, it is placed before the items
of the sequence in the calculation, and serves as a default when the
sequence is empty.

 

意思就是对sequence连续使用function, 如果不给出initial, 则第一次调用传递sequence的两个元素, 以后把前一次调用的结果和sequence的下一个元素传递给function. 如果给出initial, 则第一次传递initial和sequence的第一个元素给function.

from functools import reduce  
reduce(lambda x,y: x+y, [1, 2, 3])  
输出 6  
reduce(lambda x, y: x+y, [1,2,3], 9)  
输出 15  
reduce(lambda x,y: x+y, [1, 2, 3], 7)  
输出 13  

  

*functool标准库还有很多功能,可以参考网上的资料

以上是关于Python的functools.reduce用法的主要内容,如果未能解决你的问题,请参考以下文章

384reduce 归纳函数的用法

python学习笔记 -- reduce合并减少

使用 functools.reduce 时出现属性错误

chapter5.4Python之functools

使用 Python 的 reduce() 加入多个 PySpark DataFrames

Python连载16-reduce函数&filter函数