python中reduce()函数的使用方法示例


Posted in Python onSeptember 29, 2017

前言

本文主要给大家介绍了关于python中reduce()函数使用的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍:

reduce()函数在库functools里,如果要使用它,要从这个库里导入。reduce函数与map函数有不一样地方,map操作是并行操作,reduce函数是把多个参数合并的操作,也就是从多个条件简化的结果,在计算机的算法里,大多数情况下,就是为了简单化。比如识别图像是否是一只猫,那么就是从众多的像素里提炼出来一个判断:是或否。可能是几百万个像素,就只出来一个结果。在GOOGLE大规模集群里,就是利用这个思想,把前面并行处理的操作叫做map,并行处理之后的结果,就需要简化,归类,把这个简化和归类的过程就叫做reduce。由于reduce只能在一台主机上操作,并不能分布式地处理,但是reduce处理的是map结果,那么意味着这些结果已经非常简单,数据量大大减小,处理起来就非常快。

因此可以把mapreduce过程叫做分析归纳的过程。

看一下面reduce()的例子:

#python 3. 6 
#蔡军生 
#http://blog.csdn.net/caimouse/article/details/51749579 
# 
from functools import reduce 
 
result = reduce(lambda x, y: x+y, [1, 2, 3, 4, 5]) 
print(result)

输出结果:

15

在这个例子里,其实计算过程是这样的:

((((1+2)+3)+4)+5)

python中reduce()函数的使用方法示例

再看一个阶乘的例子:

#python 3. 6 
#蔡军生 
#http://blog.csdn.net/caimouse/article/details/51749579 
# 
from functools import reduce 
 
n = 3 
print(reduce(lambda x, y: x * y, range(1, n + 1))) # 6

输出结果:

6

reduce函数,reduce函数会对参数序列中元素进行累积。

reduce函数的定义:

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

function参数是一个有两个参数的函数,reduce依次从sequence中取一个元素,和上一次调用function的结果做参数再次调用function。

第一次调用function时,如果提供initial参数,会以sequence中的第一个元素和initial作为参数调用function,否则会以序列sequence中的前两个元素做参数调用function。

reduce(lambda x, y: x + y, [2, 3, 4, 5, 6], 1)

结果为21(  (((((1+2)+3)+4)+5)+6)  )

reduce(lambda x, y: x + y, [2, 3, 4, 5, 6])

结果为20

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
把项目从Python2.x移植到Python3.x的经验总结
Apr 20 Python
独特的python循环语句
Nov 20 Python
Python面向对象进阶学习
May 21 Python
python3.6环境安装+pip环境配置教程图文详解
Jun 20 Python
Python爬虫实现的根据分类爬取豆瓣电影信息功能示例
Sep 15 Python
python网络爬虫 CrawlSpider使用详解
Sep 27 Python
Python递归及尾递归优化操作实例分析
Feb 01 Python
pytorch实现CNN卷积神经网络
Feb 19 Python
基于python实现删除指定文件类型
Jul 21 Python
python爬虫---requests库的用法详解
Sep 28 Python
使用python画出逻辑斯蒂映射(logistic map)中的分叉图案例
Dec 11 Python
如何在向量化NumPy数组上进行移动窗口
May 18 Python
Django Admin 实现外键过滤的方法
Sep 29 #Python
python 调用c语言函数的方法
Sep 29 #Python
python文件名和文件路径操作实例
Sep 29 #Python
Python 实现简单的shell sed替换功能(实例讲解)
Sep 29 #Python
Python 基础教程之闭包的使用方法
Sep 29 #Python
python下实现二叉堆以及堆排序的示例
Sep 29 #Python
Python数据结构与算法之链表定义与用法实例详解【单链表、循环链表】
Sep 28 #Python
You might like
php操作xml
2013/10/27 PHP
php设计模式之策略模式应用案例详解
2019/06/17 PHP
Laravel 5.2 文档 数据库 ―― 起步介绍
2019/10/21 PHP
用JavaScript和注册表脚本实现右键收藏Web页选中文本
2007/01/28 Javascript
js 获取服务器控件值的代码
2010/03/05 Javascript
js对象的比较
2011/02/26 Javascript
javascript开发技术大全-第3章 js数据类型
2011/07/03 Javascript
JavaScript Scoping and Hoisting 翻译
2012/07/03 Javascript
js拖拽一些常见的思路方法整理
2014/03/19 Javascript
javascript版2048小游戏
2015/03/18 Javascript
JavaScript将一个数组插入到另一个数组的方法
2015/03/19 Javascript
jquery实现图片预加载
2015/12/25 Javascript
Vue.js 和 MVVM 的注意事项
2016/11/07 Javascript
使用FileReader API创建Vue文件阅读器组件
2018/04/03 Javascript
解决vue v-for 遍历循环时key值报错的问题
2018/09/06 Javascript
详解JavaScript作用域和作用域链
2019/03/19 Javascript
Vue使用Canvas绘制图片、矩形、线条、文字,下载图片
2019/04/26 Javascript
使用Python程序抓取新浪在国内的所有IP的教程
2015/05/04 Python
python实现批量按比例缩放图片效果
2018/03/30 Python
Win10下python 2.7.13 安装配置方法图文教程
2018/09/18 Python
使用 Visual Studio Code(VSCode)搭建简单的Python+Django开发环境的方法步骤
2018/12/17 Python
python设定并获取socket超时时间的方法
2019/01/12 Python
python numpy--数组的组合和分割实例
2020/02/24 Python
python新手学习使用库
2020/06/11 Python
英国女士家居服网站:hush
2017/08/09 全球购物
实习生个人找工作的自我评价
2013/10/30 职场文书
房产销售经理职责
2013/12/20 职场文书
心得体会开头
2014/01/01 职场文书
运动会跳远广播稿
2014/02/04 职场文书
4s店市场专员岗位职责
2014/04/09 职场文书
党支部承诺书
2015/01/20 职场文书
共青团员自我评价
2015/03/10 职场文书
PYTHON使用Matplotlib去实现各种条形图的绘制
2022/03/22 Python
Python多线程实用方法以及共享变量资源竞争问题
2022/04/12 Python
vue elementUI表格控制对应列
2022/04/13 Vue.js
MySQL 自动填充 create_time 和 update_time
2022/05/20 MySQL