python内置函数reduce 和 map/filter等函数有点类似,都是通过函数对迭代器中的元素进行遍历操作,唯一区别是reduce函数是返回计算结果是一个值,而map/filter是返回一个序列或者迭代器,下面在做详细解释
一.reduce函数简介
1.语法
代码语言:javascript复制from functools import reduce # 导入模块
reduce(function, sequence[, initial])
参数介绍:
function – 有两个参数的函数, 必需参数;
sequence – tuple ,list ,dictionary, string等可迭代物,必需参数;
initial – 初始值, 可选参数;
返回值:返回计算结果;
2.原理 – 把上一次计算的结果作为下一次的计算的输入
reduce的工作过程是 :在迭代sequence(tuple ,list ,dictionary, string等可迭代物)的过程中,首先把 前两个元素传给 函数参数,函数加工后,然后把得到的结果和第三个元素作为两个参数传给函数参数, 函数加工后得到的结果又和第四个元素作为两个参数传给函数参数,依次类推。 如果传入了 initial 值, 那么首先传的就不是 sequence 的第一个和第二个元素,而是 initial值和 第一个元素。经过这样的累计计算之后合并序列到一个单一返回值;
代码语言:javascript复制例如:reduce(lambda x, y: x y, [1, 2, 3, 4, 5]) 计算的就是((((1 2) 3) 4) 5) = 15
二.reduce函数使用
1.reduce函数普通使用
代码语言:javascript复制# !usr/bin/env python
# -*- coding:utf-8 _*-
"""
@Author:何以解忧
@Blog(个人博客地址): https://www.codersrc.com/
@File:python_reduce.py
@Time:2020/3/6 10:25
@Motto:不积跬步无以至千里,不积小流无以成江海,程序人生的精彩需要坚持不懈地积累!
"""
from functools import reduce # 导入模块
def func1(x,y):
# 把上一次计算的结果作为下一次的计算的输入
print("x=%d y=%d x*y=%d"%(x,y,x*y))
return x*y
if __name__ == "__main__":
list1 = [1,2,3,4,5]
value = reduce(func1,list1) #等价 1*2*3*4*5 = 120
print(value)
print(type(value))
输出结果:
代码语言:javascript复制x=1 y=2 x*y=2
x=2 y=3 x*y=6
x=6 y=4 x*y=24
x=24 y=5 x*y=120
120
<class 'int'>
实际上这个函数很简单:把上一次计算的结果作为下一次的计算的输入!
2.reduce函数配合匿名函数使用
代码语言:javascript复制if __name__ == "__main__":
list1 = [1,2,3,4,5]
value = reduce(lambda x,y : x*y ,list1) #等价 1*2*3*4*5 = 120
print(value)
print(type(value))
输出结果:
代码语言:javascript复制120
<class 'int'>
3.reduce函数设置可选参数initial
代码语言:javascript复制from functools import reduce # 导入模块
def func1(x,y):
return x*y
if __name__ == "__main__":
list1 = [1,2,3,4,5]
value = reduce(func1,list1,50) #等价 50*1*2*3*4*5 = 6000
print(value)
print(type(value))
输出结果:
代码语言:javascript复制6000
<class 'int'>