使用Python的toolz库开始函数式编程的方法


Posted in Python onNovember 15, 2018

在这个由两部分组成的系列文章的第二部分中,我们将继续探索如何将函数式编程方法中的好想法引入到 Python中,以实现两全其美。

在上一篇文章中,我们介绍了不可变数据结构 。 这些数据结构使得我们可以编写“纯”函数,或者说是没有副作用的函数,仅仅接受一些参数并返回结果,同时保持良好的性能。

在这篇文章中,我们使用 toolz 库来构建。 这个库具有操作此类函数的函数,并且它们在纯函数中表现得特别好。 在函数式编程世界中,它们通常被称为“高阶函数”,因为它们将函数作为参数,将函数作为结果返回。

让我们从这里开始:

def add_one_word(words,word):
 return words.set(words.get(word, 0) + 1)

这个函数假设它的第一个参数是一个不可变的类似字典的对象,它返回一个新的类似字典的在相关位置递增的对象:这就是一个简单的频率计数器。

但是,只有将它应用于单词流并做 归纳 时才有用。 我们可以使用内置模块 functools 中的归纳器。

functools.reduce(function,stream,initializer)

我们想要一个函数,应用于流,并且能能返回频率计数。

我们首先使用 toolz.curry 函数:

add_all_words=curry(functools.reduce,add_one_word)

使用此版本,我们需要提供初始化程序。但是,我们不能只将 pyrsistent.m 函数添加到 curry 函数中; 因为这个顺序是错误的。

add_all_words_flipped=flip(add_all_words)

flip 这个高阶函数返回一个调用原始函数的函数,并且翻转参数顺序。

get_all_words=add_all_words_flipped(pyrsistent.m())

我们利用 flip 自动调整其参数的特性给它一个初始值:一个空字典。

现在我们可以执行 get_all_words(word_stream) 这个函数来获取频率字典。 但是,我们如何获得一个单词流呢? Python 文件是按行供流的。

def to_words(lines):
 for line in lines:
  yield from line.split()

在单独测试每个函数后,我们可以将它们组合在一起:

words_from_file=toolz.compose(get_all_words,to_words)

在这种情况下,组合只是使两个函数很容易阅读:首先将文件的行流应用于 to_words ,然后将 get_all_words 应用于 to_words 的结果。 但是文字上读起来似乎与代码执行相反。

当我们开始认真对待可组合性时,这很重要。有时可以将代码编写为一个单元序列,单独测试每个单元,最后将它们全部组合。如果有几个组合元素时,组合的顺序可能就很难理解。

toolz 库借用了 Unix 命令行的做法,并使用 pipe 作为执行相同操作的函数,但顺序相反。

words_from_file=toolz.pipe(to_words,get_all_words)

现在读起来更直观了:将输入传递到 to_words ,并将结果传递给 get_all_words 。 在命令行上,等效写法如下所示:

$cat files|to_words|get_all_words

toolz 库允许我们操作函数,切片、分割和组合,以使我们的代码更容易理解和测试。

总结

以上所述是小编给大家介绍的使用Python的toolz库开始函数式编程,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Python 相关文章推荐
python调用cmd命令行制作刷博器
Jan 13 Python
Python中使用partial改变方法默认参数实例
Apr 28 Python
利用Python批量压缩png方法实例(支持过滤个别文件与文件夹)
Jul 30 Python
pymongo中聚合查询的使用方法
Mar 22 Python
Python中如何导入类示例详解
Apr 17 Python
对python tkinter窗口弹出置顶的方法详解
Jun 14 Python
keras模型可视化,层可视化及kernel可视化实例
Jan 24 Python
Python过滤掉numpy.array中非nan数据实例
Jun 08 Python
python编写实现抽奖器
Sep 10 Python
Python+unittest+DDT实现数据驱动测试
Nov 30 Python
python 根据列表批量下载网易云音乐的免费音乐
Dec 03 Python
详解appium自动化测试工具(monitor、uiautomatorviewer)
Jan 27 Python
Python中is和==的区别详解
Nov 15 #Python
Python中垃圾回收和del语句详解
Nov 15 #Python
Matplotlib中文乱码的3种解决方案
Nov 15 #Python
Python使用sorted对字典的key或value排序
Nov 15 #Python
python并发和异步编程实例
Nov 15 #Python
Numpy截取指定范围内的数据方法
Nov 14 #Python
python numpy元素的区间查找方法
Nov 14 #Python
You might like
PHP多线程抓取网页实现代码
2010/07/22 PHP
PHP中将ip地址转成十进制数的两种实用方法
2013/08/15 PHP
PHP中filter函数校验数据的方法详解
2015/07/31 PHP
解决ThinkPHP下使用上传插件Uploadify浏览器firefox报302错误的方法
2015/12/18 PHP
SCP远程VPS快速搬家和WDCP升级php5.3安装memcached和eaccelerator教程
2017/07/27 PHP
PHP开发的文字水印,缩略图,图片水印实现类与用法示例
2019/04/12 PHP
laravel 解决crontab不执行的问题
2019/10/22 PHP
php + ajax 实现的写入数据库操作简单示例
2020/05/16 PHP
struts2 jquery 打造无限层次的树
2009/10/23 Javascript
使用jQuery.Validate进行客户端验证(初级篇) 不使用微软验证控件的理由
2010/06/28 Javascript
javascript移出节点removeChild()使用介绍
2014/04/03 Javascript
javascript学习笔记(八)正则表达式
2014/10/08 Javascript
jQuery关键词说明插件cluetip使用指南
2015/04/21 Javascript
js验证真实姓名与身份证号是否匹配
2015/10/13 Javascript
基于jquery实现日历签到功能
2020/09/11 Javascript
在Web项目中引入Jquery插件报错的完美解决方案(图解)
2016/09/19 Javascript
BootStrap tooltip提示框使用小结
2016/10/26 Javascript
input file样式修改以及图片预览删除功能详细概括(推荐)
2017/08/17 Javascript
一次记住JavaScript的6个正则表达式方法
2018/02/22 Javascript
JS中promise化微信小程序api
2018/04/12 Javascript
Angular Material Icon使用详解
2018/11/07 Javascript
微信小程序纯文本实现@功能
2020/04/08 Javascript
让Vue响应Map或Set的变化操作
2020/11/11 Javascript
[47:26]完美世界DOTA2联赛 LBZS vs Forest 第二场 11.07
2020/11/09 DOTA
python实现人人自动回复、抢沙发功能
2018/06/08 Python
简单了解python协程的相关知识
2019/08/31 Python
使用Python爬取弹出窗口信息的实例
2020/03/14 Python
使用css创建三角形 使用CSS3创建3d四面体原理及代码(html5实践)
2013/01/06 HTML / CSS
火山动力Java笔试题
2014/06/26 面试题
电脑饰品店的创业计划书
2014/01/21 职场文书
超市优秀员工事迹材料
2014/05/01 职场文书
文明礼仪伴我行演讲稿
2014/05/12 职场文书
民间借贷借条范本
2015/05/25 职场文书
教师读书笔记
2015/06/29 职场文书
如何用python插入独创性声明
2021/03/31 Python
Python使用sql语句对mysql数据库多条件模糊查询的思路详解
2021/04/12 Python