Python标准库之循环器(itertools)介绍


Posted in Python onNovember 25, 2014

在循环对象和函数对象中,我们了解了循环器(iterator)的功能。循环器是对象的容器,包含有多个对象。通过调用循环器的next()方法 (__next__()方法,在Python 3.x中),循环器将依次返回一个对象。直到所有的对象遍历穷尽,循环器将举出StopIteration错误。

在for i in iterator结构中,循环器每次返回的对象将赋予给i,直到循环结束。使用iter()内置函数,我们可以将诸如表、字典等容器变为循环器。比如:

for i in iter([2, 4, 5, 6]):

    print(i)

标准库中的itertools包提供了更加灵活的生成循环器的工具。这些工具的输入大都是已有的循环器。另一方面,这些工具完全可以自行使用Python实现,该包只是提供了一种比较标准、高效的实现方式。这也符合Python“只有且最好只有解决方案”的理念。

# import the tools

from itertools import *

无穷循环器

count(5, 2)     #从5开始的整数循环器,每次增加2,即5, 7, 9, 11, 13, 15 ...
cycle('abc')    #重复序列的元素,既a, b, c, a, b, c ...
repeat(1.2)     #重复1.2,构成无穷循环器,即1.2, 1.2, 1.2, ...

repeat也可以有一个次数限制:

repeat(10, 5)   #重复10,共重复5次

函数式工具

函数式编程是将函数本身作为处理对象的编程范式。在Python中,函数也是对象,因此可以轻松的进行一些函数式的处理,比如map(), filter(), reduce()函数。

itertools包含类似的工具。这些函数接收函数作为参数,并将结果返回为一个循环器。

比如:

from itertools import *

rlt = imap(pow, [1, 2, 3], [1, 2, 3])

for num in rlt:

    print(num)

上面显示了imap函数。该函数与map()函数功能相似,只不过返回的不是序列,而是一个循环器。包含元素1, 4, 27,即1**1, 2**2, 3**3的结果。函数pow(内置的乘方函数)作为第一个参数。pow()依次作用于后面两个列表的每个元素,并收集函数结果,组成返回的循环器。

此外,还可以用下面的函数:

starmap(pow, [(1, 1), (2, 2), (3, 3)])

pow将依次作用于表的每个tuple。

ifilter函数与filter()函数类似,只是返回的是一个循环器。

ifilter(lambda x: x > 5, [2, 3, 5, 6, 7]

将lambda函数依次作用于每个元素,如果函数返回True,则收集原来的元素。6, 7

此外,

ifilterfalse(lambda x: x > 5, [2, 3, 5, 6, 7])

与上面类似,但收集返回False的元素。2, 3, 5
takewhile(lambda x: x < 5, [1, 3, 6, 7, 1])

当函数返回True时,收集元素到循环器。一旦函数返回False,则停止。1, 3
dropwhile(lambda x: x < 5, [1, 3, 6, 7, 1])

当函数返回False时,跳过元素。一旦函数返回True,则开始收集剩下的所有元素到循环器。6, 7, 1。

组合工具

我们可以通过组合原有循环器,来获得新的循环器。

chain([1, 2, 3], [4, 5, 7])      # 连接两个循环器成为一个。1, 2, 3, 4, 5, 7

product('abc', [1, 2])   # 多个循环器集合的笛卡尔积。相当于嵌套循环  

for m, n in product('abc', [1, 2]):

    print m, n

permutations('abc', 2)   # 从'abcd'中挑选两个元素,比如ab, bc, ... 将所有结果排序,返回为新的循环器。

注意,上面的组合分顺序,即ab, ba都返回。

combinations('abc', 2)   # 从'abcd'中挑选两个元素,比如ab, bc, ... 将所有结果排序,返回为新的循环器。

注意,上面的组合不分顺序,即ab, ba的话,只返回一个ab。

combinations_with_replacement('abc', 2) # 与上面类似,但允许两次选出的元素重复。即多了aa, bb, cc。

groupby()

将key函数作用于原循环器的各个元素。根据key函数结果,将拥有相同函数结果的元素分到一个新的循环器。每个新的循环器以函数返回结果为标签。

这就好像一群人的身高作为循环器。我们可以使用这样一个key函数: 如果身高大于180,返回"tall";如果身高底于160,返回"short";中间的返回"middle"。最终,所有身高将分为三个循环器,即"tall", "short", "middle"。

def height_class(h):

     if h > 180:

        return "tall"

     elif h < 160:

        return "short"

     else:

        return "middle"friends = [191, 158, 159, 165, 170, 177, 181, 182, 190] friends = sorted(friends, key = height_class)

 

for m, n in groupby(friends, key = height_class):

    print(m)

    print(list(n))

注意,groupby的功能类似于UNIX中的uniq命令。分组之前需要使用sorted()对原循环器的元素,根据key函数进行排序,让同组元素先在位置上靠拢。

其它工具

compress('ABCD', [1, 1, 1, 0])  # 根据[1, 1, 1, 0]的真假值情况,选择第一个参数'ABCD'中的元素。A, B, C
islice()                        # 类似于slice()函数,只是返回的是一个循环器
izip()                          # 类似于zip()函数,只是返回的是一个循环器。

总结

itertools的工具都可以自行实现。itertools只是提供了更加成形的解决方案。

Python 相关文章推荐
一个基于flask的web应用诞生 用户注册功能开发(5)
Apr 11 Python
Python使用Turtle模块绘制五星红旗代码示例
Dec 11 Python
TensorFlow深度学习之卷积神经网络CNN
Mar 09 Python
Python爬虫爬取新浪微博内容示例【基于代理IP】
Aug 03 Python
python for 循环获取index索引的方法
Feb 01 Python
Python3利用print输出带颜色的彩色字体示例代码
Apr 08 Python
Python中断多重循环的思路总结
Oct 04 Python
Python使用selenium + headless chrome获取网页内容的方法示例
Oct 16 Python
Python中如何添加自定义模块
Jun 09 Python
Django跨域请求原理及实现代码
Nov 14 Python
python3 kubernetes api的使用示例
Jan 12 Python
python 字典和列表嵌套用法详解
Jun 29 Python
Python标准库之sqlite3使用实例
Nov 25 #Python
Python标准库内置函数complex介绍
Nov 25 #Python
Python XML RPC服务器端和客户端实例
Nov 22 #Python
Python实现读取目录所有文件的文件名并保存到txt文件代码
Nov 22 #Python
python进程类subprocess的一些操作方法例子
Nov 22 #Python
Python读取环境变量的方法和自定义类分享
Nov 22 #Python
Python中的引用和拷贝浅析
Nov 22 #Python
You might like
动画 《Pokemon Sword·Shield》系列WEB动画《薄明之翼》第2话声优阵容公开!
2020/03/06 日漫
php类中的$this,static,final,const,self这几个关键字使用方法
2015/12/14 PHP
360搜索引擎自动收录php改写方案
2018/04/28 PHP
php设计模式之观察者模式实例详解【星际争霸游戏案例】
2020/03/30 PHP
用javascript实现的图片马赛克后显示并切换加文字功能
2007/04/21 Javascript
Expandable &quot;Detail&quot; Table Rows
2007/08/29 Javascript
js弹出模式对话框,并接收回传值的方法
2013/03/12 Javascript
JavaScript打印iframe内容示例代码
2013/08/20 Javascript
浅析用prototype定义自己的方法
2013/11/14 Javascript
js 获取、清空input type=&quot;file&quot;的值示例代码
2014/02/19 Javascript
js实现兼容IE和FF的上下层的移动
2015/05/04 Javascript
简介JavaScript中的push()方法的使用
2015/06/09 Javascript
jQuery实现鼠标滑过链接控制图片的滑动展开与隐藏效果
2015/10/28 Javascript
jQuery+json实现动态创建复杂表格table的方法
2016/10/25 Javascript
Angular4 组件通讯方法大全(推荐)
2018/07/12 Javascript
nodejs中函数的调用实例详解
2018/10/31 NodeJs
详解Vue中的基本语法和常用指令
2019/07/23 Javascript
vue element-ui读取pdf文件的方法
2019/11/26 Javascript
利用 python 对目录下的文件进行过滤删除
2017/12/27 Python
python多进程中的内存复制(实例讲解)
2018/01/05 Python
django多文件上传,form提交,多对多外键保存的实例
2019/08/06 Python
SpringBoot实现登录注册常见问题解决方案
2020/03/04 Python
香港化妆品经销商:我的公主
2016/08/05 全球购物
美国最好的钓鱼、狩猎和划船装备商店:Bass Pro Shops
2018/12/02 全球购物
乌克兰珠宝大卖场:Zlato.ua
2020/09/27 全球购物
法国春天百货官网:Printemps.com
2020/06/29 全球购物
材料采购员岗位职责
2013/12/17 职场文书
工会主席事迹材料
2014/06/03 职场文书
入党自荐书范文
2015/03/05 职场文书
学校捐书倡议书
2015/04/27 职场文书
帝企鹅日记观后感
2015/06/10 职场文书
元宵节晚会主持词
2015/07/01 职场文书
Python自动化之批量处理工作簿和工作表
2021/06/03 Python
使用pycharm运行flask应用程序的详细教程
2021/06/07 Python
详解MySql中InnoDB存储引擎中的各种锁
2022/02/12 MySQL
vue route新窗口跳转页面并且携带与接收参数
2022/04/10 Vue.js