介绍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 dict remove数组删除(del,pop)
Mar 24 Python
让Python代码更快运行的5种方法
Jun 21 Python
Python中的条件判断语句基础学习教程
Feb 07 Python
python 通过麦克风录音 生成wav文件的方法
Jan 09 Python
在Python函数中输入任意数量参数的实例
Jul 16 Python
python线程安全及多进程多线程实现方法详解
Sep 27 Python
使用Fabric自动化部署Django项目的实现
Sep 27 Python
wxPython窗体拆分布局基础组件
Nov 19 Python
Python中sorted()排序与字母大小写的问题
Jan 14 Python
python3连接mysql获取ansible动态inventory脚本
Jan 19 Python
Python3使用 GitLab API 进行批量合并分支
Oct 15 Python
Python中常见的反爬机制及其破解方法总结
Jun 10 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 过滤危险html代码
2009/06/29 PHP
php获取当前网址url并替换参数或网址的方法
2010/06/06 PHP
PHP 抽象方法与抽象类abstract关键字介绍及应用
2014/10/16 PHP
php实现基于微信公众平台开发SDK(demo)扩展的方法
2014/12/22 PHP
php集成套件服务器xampp安装使用教程(适合第一次玩PHP的新手)
2015/06/03 PHP
php导出中文内容excel文件类实例
2015/07/06 PHP
浅谈PHP的反射机制
2016/12/15 PHP
PHP实现二维数组根据key进行排序的方法
2016/12/30 PHP
JavaScript脚本语言在网页中的简单应用
2007/05/13 Javascript
javascript 定义新对象方法
2010/02/20 Javascript
将HTML格式的String转化为HTMLElement的实现方法
2014/08/07 Javascript
Jqgrid之强大的表格插件应用
2015/12/02 Javascript
JS仿百度自动下拉框模糊匹配提示
2016/07/25 Javascript
详解react如何在组件中获取路由参数
2017/06/15 Javascript
vue 点击按钮增加一行的方法
2018/09/07 Javascript
JavaScript使用百度ECharts插件绘制饼图操作示例
2019/11/26 Javascript
Javascript模块化机制实现原理详解
2020/04/02 Javascript
pycharm 使用心得(一)安装和首次使用
2014/06/05 Python
Ubuntu下安装PyV8
2016/03/13 Python
浅谈python的深浅拷贝以及fromkeys的用法
2019/03/08 Python
详解python tkinter教程-事件绑定
2019/03/28 Python
一行Python代码过滤标点符号等特殊字符
2019/08/12 Python
Python实现图像去噪方式(中值去噪和均值去噪)
2019/12/18 Python
python+adb命令实现自动刷视频脚本案例
2020/04/23 Python
中国领先的专业演出票务网:永乐票务
2016/08/29 全球购物
美国领先的低折扣旅行网站:Hotwire
2019/01/19 全球购物
德国Discount-Apotheke中文官网:DC德式康线上药房
2020/02/18 全球购物
小学生元旦感言
2014/02/26 职场文书
新年联欢会主持词
2014/03/27 职场文书
2015毕业生实习工作总结
2014/12/12 职场文书
优秀班主任材料
2014/12/16 职场文书
高中班主任评语
2014/12/30 职场文书
综合素质评价个性发展自我评价
2015/03/06 职场文书
请假条应该怎么写?
2019/06/24 职场文书
同学联谊会邀请函
2019/06/24 职场文书
浅谈Python项目的服务器部署
2021/04/25 Python