简单了解python高阶函数map/reduce


Posted in Python onJune 28, 2019

高阶函数map/reduce

Python内建了map()和reduce()函数。

我们先看map。map()函数接收两个参数,一个是函数,一个是Iterable,map将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator返回。

举例说明,比如我们有一个函数f(x)=x2,要把这个函数作用在一个list [1, 2, 3, 4, 5, 6, 7, 8, 9]上,就可以用map()实现如下:

简单了解python高阶函数map/reduce

现在,我们用Python代码实现:

def f(x):
return x * x
r = map(f, [1, 2, 3, 4, 5, 6, 7, 8, 9])
print list(r)

运行结果:

[1, 4, 9, 16, 25, 36, 49, 64, 81]
Process finished with exit code 0

map()传入的第一个参数是f,即函数对象本身。由于结果r是一个Iterator,Iterator是惰性序列,因此通过list()函数让它把整个序列都计算出来并返回一个list。
你可能会想,不需要map()函数,写一个循环,也可以计算出结果:

L = []
for n in [1, 2, 3, 4, 5, 6, 7, 8, 9]:
L.append(f(n))
print L

的确可以,但是,从上面的循环代码,能一眼看明白“把f(x)作用在list的每一个元素并把结果生成一个新的list”吗?

所以,map()作为高阶函数,事实上它把运算规则抽象了,因此,我们不但可以计算简单的f(x)=x2,还可以计算任意复杂的函数,比如,把这个list所有数字转为字符串:

print list(map(str, [1, 2, 3, 4, 5, 6, 7, 8, 9]))

运行结果:

['1', '2', '3', '4', '5', '6', '7', '8', '9']
Process finished with exit code 0

只需要一行代码。

再看reduce的用法。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
print reduce(add, [1, 3, 5, 7, 9])

运行结果:

25
Process finished with exit code 0

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

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

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

运行结果:

13579
Process finished with exit code 0

这个例子本身没多大用处,但是,如果考虑到字符串str也是一个序列,对上面的例子稍加改动,配合map(),我们就可以写出把str转换为int的函数:

def fn(x, y):
return x * 10 + y
def char2num(s):
digits = {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}
return digits[s]
print reduce(fn, map(char2num, '13579'))

运行结果:

13579
Process finished with exit code 0

整理成一个str2int的函数就是:

from functools import reduce
DIGITS = {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}
def str2int(s):
def fn(x, y):
return x * 10 + y
def char2num(s):
return DIGITS[s]
return reduce(fn, map(char2num, s))

还可以用lambda函数进一步简化成:

from functools import reduce
DIGITS = {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}
def char2num(s):
return DIGITS[s]
def str2int(s):
return reduce(lambda x, y: x * 10 + y, map(char2num, s))

也就是说,假设Python没有提供int()函数,你完全可以自己写一个把字符串转化为整数的函数,而且只需要几行代码!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
使用Python的urllib2模块处理url和图片的技巧两则
Feb 18 Python
python操作 hbase 数据的方法
Dec 18 Python
Python获取某一天是星期几的方法示例
Jan 17 Python
python+pygame简单画板实现代码实例
Dec 13 Python
python+pandas生成指定日期和重采样的方法
Apr 11 Python
谈一谈基于python的面向对象编程基础
May 21 Python
详解python3中用HTMLTestRunner.py报ImportError: No module named 'StringIO'如何解决
Aug 27 Python
如何基于python操作excel并获取内容
Dec 24 Python
基于python实现上传文件到OSS代码实例
May 09 Python
Python基于数列实现购物车程序过程详解
Jun 09 Python
python实现发送带附件的邮件代码分享
Sep 22 Python
Python系统公网私网流量监控实现流程
Nov 23 Python
安装好Pycharm后如何配置Python解释器简易教程
Jun 28 #Python
关于 Python opencv 使用中的 ValueError: too many values to unpack
Jun 28 #Python
python识别图像并提取文字的实现方法
Jun 28 #Python
python3射线法判断点是否在多边形内
Jun 28 #Python
python opencv 批量改变图片的尺寸大小的方法
Jun 28 #Python
python如何实现代码检查
Jun 28 #Python
python射线法判断一个点在图形区域内外
Jun 28 #Python
You might like
PHP flush()与ob_flush()的区别详解
2013/06/03 PHP
PHP入门之常量简介和系统常量
2014/05/12 PHP
关于URL最大长度限制的相关资料查证
2014/12/23 PHP
编写PHP脚本过滤用户上传的图片
2015/07/03 PHP
Yii清理缓存的方法
2016/01/06 PHP
js chrome浏览器判断代码
2010/03/28 Javascript
使用变量动态设置js的属性名
2014/10/19 Javascript
流量统计器如何鉴别C#:WebBrowser中伪造referer
2015/01/07 Javascript
JavaScript实现文字与图片拖拽效果的方法
2015/02/16 Javascript
window.onload绑定多个事件的两种解决方案
2016/05/15 Javascript
前端学习笔记style,currentStyle,getComputedStyle的用法与区别
2016/05/28 Javascript
Bootstrap基本组件学习笔记之进度条(15)
2016/12/08 Javascript
原生的强大DOM选择器querySelector介绍
2016/12/21 Javascript
Vue.js学习记录之在元素与template中使用v-if指令实例
2017/06/27 Javascript
vue引入jq插件的实例讲解
2017/09/12 Javascript
JavaScript数组的5种迭代方法
2017/09/29 Javascript
vue计算属性和监听器实例解析
2018/05/10 Javascript
浅谈Vue render函数在ElementUi中的应用
2018/09/06 Javascript
iview实现select tree树形下拉框的示例代码
2018/12/21 Javascript
详解Vue中的基本语法和常用指令
2019/07/23 Javascript
p5.js实现简单货车运动动画
2019/10/23 Javascript
Element DateTimePicker日期时间选择器的使用示例
2020/07/27 Javascript
js和jquery判断数据类型的4种方法总结
2020/08/28 jQuery
springboot+vue+对接支付宝接口+二维码扫描支付功能(沙箱环境)
2020/10/15 Javascript
sqlalchemy对象转dict的示例
2014/04/22 Python
深入解析Python中的descriptor描述器的作用及用法
2016/06/27 Python
Python实现的绘制三维双螺旋线图形功能示例
2018/06/23 Python
解决项目pycharm能运行,在终端却无法运行的问题
2019/01/19 Python
python工具——Mimesis的简单使用教程
2021/01/16 Python
CSS3毛玻璃效果(blur)有白边问题的解决方法
2016/11/15 HTML / CSS
CSS3 画基本图形,圆形、椭圆形、三角形等
2016/09/20 HTML / CSS
极简鞋类,赤脚的感觉:Lems Shoes
2019/08/06 全球购物
地理教师岗位职责
2014/03/16 职场文书
2014校长四风问题对照检查材料思想汇报
2014/09/16 职场文书
2014年扶贫工作总结
2014/11/18 职场文书
铁头也玩根德 YachtBoy YB-230......
2022/04/05 无线电