使用Python的toolz库开始函数式编程的方法
作者:佚名 发布时间:2022-10-18 10:29:55
在这个由两部分组成的系列文章的第二部分中,我们将继续探索如何将函数式编程方法中的好想法引入到 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库开始函数式编程网站的支持!
来源:http://developer.51cto.com/art/201811/586957.htm
猜你喜欢
- 今天使用python写了一个简单的爬虫,用来下载taptap网站的游戏截图。下面说下具体的实现方法。在搜索框中搜索“原神”打开浏览器的开发者
- Mysql数据库常用命令:启动Mysql数据库C:》cd Mysql5.0 binC:Mysql5.0 bin》mysqld –instal
- 自执行函数:自动执行的函数。它在被解释时就已经在运行了。一般函数都是在被调用时才会执行的。 自执行函数的一般格式:(function() {
- 0.环境说明win10 64bit,电脑也是64bit的处理器,电脑装有vs2010 64bit,但是为了保险起见,只试验了32位的安装,等
- 前言相关性分析算是很多算法以及建模的基础知识之一了,十分经典。关于许多特征关联关系以及相关趋势都可以利用相关性分析计算表达。其中常见的相关性
- 安装pygal,可参阅:pip和pygal的安装实例教程基本XY线:import pygalfrom math import cos&quo
- 据了解绝大多数开发人员对于索引的理解都是一知半解,局限于大多数日常工作没有机会、也什么没有必要去关心、了解索引,实在哪天某个查询太慢了找到查
- numpy官方文档meshgrid函数帮助文档https://docs.scipy.org/doc/numpy/reference/gene
- python实现两个文本合并employee文件中记录了工号和姓名cat employee.txt:100 Jason Smith200 J
- 简介使用Pandas的pivot方法可以将DF进行旋转变换,本文将会详细讲解pivot的秘密。使用Pivotpivot用来重组DF,使用指定
- 如下所示:#!/usr/bin/env python# -*- coding: utf-8 -*-# @Time : 2018/7/13 1
- 本文实例讲述了Python通过TensorFLow进行线性模型训练原理与实现方法。分享给大家供大家参考,具体如下:1、相关概念例如要从一个线
- 1、为图片加入水印功能 Dim Jpeg Set Jpeg = Server.Create
- 小小程序猿SQL Server认知的成长 1.没毕业或工作没多久,只知道有数据库、SQL这么个东东,浑然分不清SQL和Sql Server
- #环境win64+anaconda+python3.6list & array(1)list不具有array的全部属性(如维度、转置
- 在任何语言中,都会规定某些对象(属性、方法、函数、类等)只能够在某个范围内访问,出了这个范围就不能访问了。这是“公”、“私”之分。此外,还会
- 为了组织search线的设计师交流会,特地去准备了一些资料。《SERP 2010》是其中一个,但是由于时间关系没有进行讨论。原著是英文报告,
- 现在假如要写一个按照"标题",'内容','作者'等等进行针对性的选择,这时需要涉及到使用
- 在使用出colab进行模型训练时,发现colab的python版本更新为了3.7.11,而我的代码要在python3.6下才行配置好环境,于
- 最近在研究雨哲软件采集程序的时候,需要获取真实软件地址时遇到了需要读取跳转页面跳转后的真实地址的问题。在网上找了很多方法,使用WinHttp