介绍Python中内置的itertools模块


Posted in Python onApril 29, 2015

Python的内建模块itertools提供了非常有用的用于操作迭代对象的函数。

首先,我们看看itertools提供的几个“无限”迭代器:

>>> import itertools
>>> natuals = itertools.count(1)
>>> for n in natuals:
...   print n
...
1
2
3
...

因为count()会创建一个无限的迭代器,所以上述代码会打印出自然数序列,根本停不下来,只能按Ctrl+C退出。

cycle()会把传入的一个序列无限重复下去:

>>> import itertools
>>> cs = itertools.cycle('ABC') # 注意字符串也是序列的一种
>>> for c in cs:
...   print c
...
'A'
'B'
'C'
'A'
'B'
'C'
...

同样停不下来。

repeat()负责把一个元素无限重复下去,不过如果提供第二个参数就可以限定重复次数:

>>> ns = itertools.repeat('A', 10)
>>> for n in ns:
...   print n
...

打印10次'A'

无限序列只有在for迭代时才会无限地迭代下去,如果只是创建了一个迭代对象,它不会事先把无限个元素生成出来,事实上也不可能在内存中创建无限多个元素。

无限序列虽然可以无限迭代下去,但是通常我们会通过takewhile()等函数根据条件判断来截取出一个有限的序列:

>>> natuals = itertools.count(1)
>>> ns = itertools.takewhile(lambda x: x <= 10, natuals)
>>> for n in ns:
...   print n
...

打印出1到10

itertools提供的几个迭代器操作函数更加有用:
chain()

chain()可以把一组迭代对象串联起来,形成一个更大的迭代器:

for c in chain('ABC', 'XYZ'):
  print c
# 迭代效果:'A' 'B' 'C' 'X' 'Y' 'Z'

groupby()

groupby()把迭代器中相邻的重复元素挑出来放在一起:

>>> for key, group in itertools.groupby('AAABBBCCAAA'):
...   print key, list(group) # 为什么这里要用list()函数呢?
...
A ['A', 'A', 'A']
B ['B', 'B', 'B']
C ['C', 'C']
A ['A', 'A', 'A']

实际上挑选规则是通过函数完成的,只要作用于函数的两个元素返回的值相等,这两个元素就被认为是在一组的,而函数返回值作为组的key。如果我们要忽略大小写分组,就可以让元素'A'和'a'都返回相同的key:

>>> for key, group in itertools.groupby('AaaBBbcCAAa', lambda c: c.upper()):
...   print key, list(group)
...
A ['A', 'a', 'a']
B ['B', 'B', 'b']
C ['c', 'C']
A ['A', 'A', 'a']

imap()

imap()和map()的区别在于,imap()可以作用于无穷序列,并且,如果两个序列的长度不一致,以短的那个为准。

>>> for x in itertools.imap(lambda x, y: x * y, [10, 20, 30], itertools.count(1)):
...   print x
...
10
40
90

注意imap()返回一个迭代对象,而map()返回list。当你调用map()时,已经计算完毕:

>>> r = map(lambda x: x*x, [1, 2, 3])
>>> r # r已经计算出来了
[1, 4, 9]

当你调用imap()时,并没有进行任何计算:

>>> r = itertools.imap(lambda x: x*x, [1, 2, 3])
>>> r
<itertools.imap object at 0x103d3ff90>
# r只是一个迭代对象

必须用for循环对r进行迭代,才会在每次循环过程中计算出下一个元素:

>>> for x in r:
...   print x
...
1
4
9

这说明imap()实现了“惰性计算”,也就是在需要获得结果的时候才计算。类似imap()这样能够实现惰性计算的函数就可以处理无限序列:

>>> r = itertools.imap(lambda x: x*x, itertools.count(1))
>>> for n in itertools.takewhile(lambda x: x<100, r):
...   print n
...

结果是什么?

如果把imap()换成map()去处理无限序列会有什么结果?

>>> r = map(lambda x: x*x, itertools.count(1))

结果是什么?

ifilter()

不用多说了,ifilter()就是filter()的惰性实现。
小结

itertools模块提供的全部是处理迭代功能的函数,它们的返回值不是list,而是迭代对象,只有用for循环迭代的时候才真正计算。

Python 相关文章推荐
用Python实现一个简单的多线程TCP服务器的教程
May 05 Python
python对json的相关操作实例详解
Jan 04 Python
python Socket之客户端和服务端握手详解
Sep 18 Python
python Matplotlib画图之调整字体大小的示例
Nov 20 Python
利用python爬取斗鱼app中照片方法实例
Dec 03 Python
分析Python中解析构建数据知识
Jan 20 Python
Python中的默认参数实例分析
Jan 29 Python
python模拟表单提交登录图书馆
Apr 27 Python
django中media媒体路径设置的步骤
Nov 15 Python
python3 实现函数写文件路径的正确方法
Nov 27 Python
Python常用模块os.path之文件及路径操作方法
Dec 03 Python
python实现贪吃蛇双人大战
Apr 18 Python
python使用fileinput模块实现逐行读取文件的方法
Apr 29 #Python
python将字符串转换成数组的方法
Apr 29 #Python
Python中使用hashlib模块处理算法的教程
Apr 28 #Python
简单介绍Python中的struct模块
Apr 28 #Python
在Python中使用base64模块处理字符编码的教程
Apr 28 #Python
使用Python的内建模块collections的教程
Apr 28 #Python
进一步探究Python中的正则表达式
Apr 28 #Python
You might like
PHP的开合式多级菜单程序
2006/10/09 PHP
PHP小程序自动提交到自助友情连接
2009/11/24 PHP
PHP开发者常犯的10个MySQL错误更正剖析
2012/01/30 PHP
php函数指定默认值方法的小例子
2013/12/04 PHP
php数组合并array_merge()函数使用注意事项
2014/06/19 PHP
Aster vs Newbee BO5 第一场2.19
2021/03/10 DOTA
IE浏览器兼容Firefox的JS脚本的代码
2008/10/23 Javascript
JS重要知识点小结
2011/11/06 Javascript
javascript计算当月剩余天数(天数计算器)示例代码
2014/01/09 Javascript
javascript实现十六进制颜色值(HEX)和RGB格式相互转换
2014/06/20 Javascript
jQuery中:only-child选择器用法实例
2015/01/03 Javascript
js代码实现随机颜色的小方块
2015/07/30 Javascript
详解javascript中原始数据类型Null和Undefined
2015/12/17 Javascript
基于JavaScript的操作系统你听说过吗?
2016/01/28 Javascript
Javascript中浏览器窗口的基本操作总结
2016/08/18 Javascript
微信web端后退强制刷新功能的实现代码
2018/03/04 Javascript
vue-router中的hash和history两种模式的区别
2018/07/17 Javascript
利用pyinstaller或virtualenv将python程序打包详解
2017/03/22 Python
Python守护线程用法实例
2017/06/23 Python
python入门前的第一课 python怎样入门
2018/03/06 Python
在windows下Python打印彩色字体的方法
2018/05/15 Python
Python爬虫文件下载图文教程
2018/12/23 Python
python GUI库图形界面开发之PyQt5不规则窗口实现与显示GIF动画的详细方法与实例
2020/03/09 Python
Python 中由 yield 实现异步操作
2020/05/04 Python
python+selenium爬取微博热搜存入Mysql的实现方法
2021/01/27 Python
利用css3 translate完美实现表头固定效果
2017/02/28 HTML / CSS
CSS3 圆角效果
2009/07/15 HTML / CSS
在HTML5 canvas里用卷积核进行图像处理的方法
2018/05/02 HTML / CSS
加拿大最大的相机店:Henry’s
2017/05/17 全球购物
linux系统都有哪些运行级别
2012/04/15 面试题
艺术学院毕业生求职信
2014/07/09 职场文书
2015年初中元旦晚会活动总结
2014/11/28 职场文书
总经理岗位职责
2015/02/04 职场文书
学习焦裕禄观后感
2015/06/09 职场文书
56句经典英文座右铭
2019/08/09 职场文书
kubernetes集群搭建Zabbix监控平台的详细过程
2022/07/07 Servers