使用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获取CPU、内存和硬盘等windowns系统信息的2个例子
Apr 15 Python
深入解析Python中的线程同步方法
Jun 14 Python
Python中join函数简单代码示例
Jan 09 Python
python 检查文件mime类型的方法
Dec 08 Python
在Pycharm中修改文件默认打开方式的方法
Jan 17 Python
详解如何从TensorFlow的mnist数据集导出手写体数字图片
Aug 05 Python
解决python 找不到module的问题
Feb 12 Python
Python实现检测文件的MD5值来查找重复文件案例
Mar 12 Python
python的reverse函数翻转结果为None的问题
May 11 Python
Python xml、字典、json、类四种数据类型如何实现互相转换
May 27 Python
python 解决pycharm运行py文件只有unittest选项的问题
Sep 01 Python
Python中免验证跳转到内容页的实例代码
Oct 23 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实现将GB编码转换为UTF8
2006/11/25 PHP
zend framework多模块多布局配置
2011/02/26 PHP
thinkphp中的url跳转用法分析
2016/07/12 PHP
PHP面向对象五大原则之依赖倒置原则(DIP)详解
2018/04/08 PHP
Javascript Math ceil()、floor()、round()三个函数的区别
2010/03/09 Javascript
Jquery Ajax学习实例5 向WebService发出请求,返回泛型集合数据的异步调用
2010/03/17 Javascript
关于jQuery的inArray 方法介绍
2011/10/08 Javascript
jquery实现奇偶行赋值不同css值
2012/02/17 Javascript
jQuery学习笔记 操作jQuery对象 文档处理
2012/09/19 Javascript
jquery插件实现鼠标经过图片右侧显示大图的效果(类似淘宝)
2013/02/04 Javascript
jquery select多选框的左右移动 具体实现代码
2013/07/03 Javascript
jquery ajax 局部刷新小案例
2014/02/08 Javascript
JS辨别访问浏览器判断是android还是ios系统
2014/08/19 Javascript
JS扩展方法实例分析
2015/04/15 Javascript
js+html5实现canvas绘制网页时钟的方法
2016/05/21 Javascript
jQuery中layer分页器的使用
2017/03/13 Javascript
基于vue的fullpage.js单页滚动插件
2017/03/20 Javascript
Vue.set()动态的新增与修改数据,触发视图更新的方法
2018/09/15 Javascript
vue3.0 搭建项目总结(详细步骤)
2019/05/20 Javascript
通过seajs实现JavaScript的模块开发及按模块加载
2019/06/06 Javascript
JavaScript实现京东放大镜效果
2019/12/03 Javascript
python使用arp欺骗伪造网关的方法
2015/04/24 Python
在cmd中运行.py文件: python的操作步骤
2018/05/12 Python
Python统计纯文本文件中英文单词出现个数的方法总结【测试可用】
2018/07/25 Python
Python之Numpy的超实用基础详细教程
2019/10/23 Python
python topk()函数求最大和最小值实例
2020/04/02 Python
django form和field具体方法和属性说明
2020/07/09 Python
Python自动化之UnitTest框架实战记录
2020/09/08 Python
高级Java程序员面试要点
2013/08/02 面试题
造型师求职自荐信
2013/09/27 职场文书
大学生思想道德自我评价
2015/03/09 职场文书
学雷锋献爱心倡议书
2015/04/27 职场文书
cf战队宣传语
2015/07/13 职场文书
初中同学会致辞
2015/08/01 职场文书
Nginx stream 配置代理(Nginx TCP/UDP 负载均衡)
2021/11/17 Servers
Python使用DFA算法过滤内容敏感词
2022/04/22 Python