可迭代对象
Python中任意的对象,只要它定义了可以返回一个迭代器的__iter__
方法,或者定义了可以支持下标索引的__getitem__
方法,那么它就是一个可迭代对象。简单来说,可迭代对象就是能提供迭代器的任意对象,但可迭代对象本身并不一定是一个迭代器。
迭代器
任意对象,只要定义了next
(Python2) 或者__next__
方法,它就是一个迭代器。迭代完毕后继续调用__next__
方法会产生一个StopIteration
异常。for循环即通过自动捕捉这个异常来停止迭代的。
相关内置函数
- iter():可以自动根据一个可迭代对象返回一个迭代器对象。
- next():可以自动调用迭代器的
__next__()
方法。
a = iter([1,2,3])
a.__next__()
next(a)
a.__next__()
# 输出:
1
2
3
生成器
生成器也是一种迭代器,但是只能对其迭代一次。通过使用“for”循环,或者传递给任意可以进行迭代的函数和结构来遍历它们。大多数时候生成器是以函数配合yield
来实现的,可以将yield
看成一种特殊的return
,每次会顺序返回一个新值。
def func():
yield 1
yield 2
yield 3
a = func()
a.__next__()
a.__next__()
a.__next__()
# 输出:
1
2
3
生成器使用场景
因为它们并没有把所有的值存在内存中,而是在运行时生成值。因此特别适合不想同一时间将所有计算出来的大量结果集分配到内存当中时的场景,特别是当结果集里还包含循环的时候。
# 计算斐波那契数列的生成器
def fibon(n):
a = b = 1
for i in range(n):
yield a
a, b = b, a + b
for x in fibon(1000000):
print(x)
总结
了解完以上知识后,以一段综合代码进行下总结。
# Fei类中实现了__iter__方法,成为一个可迭代的类
class Fei:
@staticmethod
# 计算斐波那契数列的生成器
def fibon(n):
a = b = 1
for i in range(n):
yield a
a, b = b, a + b
# 返回一个计算前100斐波那契数列的生成器
def __iter__(self):
return Fei.fibon(100)
a = Fei()
# 使用for循环来遍历Fei类对象a
for i in a:
print(i)
下面关于Python的文章您也可能喜欢,不妨参考下:
《Python核心编程 第二版》.(Wesley J. Chun ).[高清PDF中文版] 下载见 http://www.linuxidc.com/Linux/2013-06/85425.htm
Python教程PDF合集下载 http://www.linuxidc.com/Linux/2017-04/143278.htm
零基础如何入门Python http://www.linuxidc.com/Linux/2016-10/136485.htm
Ubuntu 14.04安装Python 3.3.5 http://www.linuxidc.com/Linux/2014-05/101481.htm
CentOS 6.5 脚本自动化装 Python2.6升级2.7 http://www.linuxidc.com/Linux/2017-02/140406.htm
CentOS上源码安装Python3.4 http://www.linuxidc.com/Linux/2015-01/111870.htm
Ubuntu 14.04下Python数据处理环境搭建 http://www.linuxidc.com/Linux/2017-01/139568.htm
Python Paramiko模块安装和使用 http://www.linuxidc.com/Linux/2017-01/139973.htm
《Python开发技术详解》.( 周伟,宗杰).[高清PDF扫描版+随书视频+代码] http://www.linuxidc.com/Linux/2013-11/92693.htm
在CentOS 6.5上安装Python2.7 http://www.linuxidc.com/Linux/2016-10/136206.htm
Ubuntu 14.04 LTS下编译安装Open Babel和Python语言绑定 http://www.linuxidc.com/Linux/2017-01/139569.htm
Python常见数据结构整理 http://www.linuxidc.com/Linux/2017-02/140613.htm
本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-05/143328.htm