简单了解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中使用CasperJS获取JS渲染生成的HTML内容的教程
Apr 09 Python
黑科技 Python脚本帮你找出微信上删除你好友的人
Jan 07 Python
scrapy爬虫实例分享
Dec 28 Python
Python数据分析之双色球中蓝红球分析统计示例
Feb 03 Python
python求最大连续子数组的和
Jul 07 Python
Pycharm设置utf-8自动显示方法
Jan 17 Python
python字符串查找函数的用法详解
Jul 08 Python
Python中socket网络通信是干嘛的
May 27 Python
新手学python应该下哪个版本
Jun 11 Python
Python3爬虫发送请求的知识点实例
Jul 30 Python
python3排序的实例方法
Oct 20 Python
Python insert() / append() 用法 Leetcode实战演示
Mar 31 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中的错误处理、异常处理机制分析
2012/05/07 PHP
php静态文件生成类实例分析
2015/01/03 PHP
yii2.0框架数据库操作简单示例【添加,修改,删除,查询,打印等】
2020/04/13 PHP
一个简单的javascript类定义例子
2009/09/12 Javascript
Javascript对象属性方法汇总
2013/11/21 Javascript
javascript写的异步加载js文件函数(支持数组传参)
2014/06/07 Javascript
jquery ajax请求方式与提示用户正在处理请稍等
2014/09/01 Javascript
基于JavaScript的操作系统你听说过吗?
2016/01/28 Javascript
Jquery操作cookie记住用户名
2016/03/29 Javascript
浅析jQuery事件之on()方法绑定多个选择器,多个事件
2016/04/27 Javascript
url中的特殊符号有什么含义(推荐)
2016/06/17 Javascript
把多个JavaScript函数绑定到onload事件处理函数上的方法
2016/09/04 Javascript
canvas时钟效果
2017/02/16 Javascript
vue-cli的webpack模板项目配置文件分析
2017/04/01 Javascript
最常用的jQuery表单验证(简单)
2017/05/23 jQuery
浅谈Node.js ORM框架Sequlize之表间关系
2017/07/24 Javascript
React如何解决fetch跨域请求时session失效问题
2018/11/02 Javascript
vue+egg+jwt实现登录验证的示例代码
2019/05/18 Javascript
通过扫小程序码实现网站登陆功能
2019/08/22 Javascript
[05:29]2014DOTA2国际邀请赛 赛后专访:LGDNewbee顺利过关
2014/07/13 DOTA
Python中生成器和yield语句的用法详解
2015/04/17 Python
详解Python多线程
2016/11/14 Python
Python调用ctypes使用C函数printf的方法
2017/08/23 Python
python dataframe astype 字段类型转换方法
2018/04/11 Python
python实现矩阵打印
2019/03/02 Python
详解python解压压缩包的五种方法
2019/07/05 Python
Python新手学习函数默认参数设置
2020/06/03 Python
详解CSS3的图层阴影和文字阴影效果使用
2016/06/09 HTML / CSS
澳大利亚领先的宠物用品商店:VetSupply
2017/09/08 全球购物
一份比较全的PHP面试题
2016/07/29 面试题
给儿子的表扬信
2014/01/15 职场文书
工作疏忽检讨书
2014/01/25 职场文书
学生安全责任书
2014/04/15 职场文书
汽车修理厂管理制度
2015/08/05 职场文书
爱岗敬业先进典型事迹材料(2016推荐版)
2016/02/26 职场文书
HTML页面点击按钮关闭页面的多种方式
2022/12/24 HTML / CSS