迭代器
迭代器与循环一样能够用来遍历元素。只不过迭代器每一次开始都是上一次的结果,
而循环每一次开始都是列表的下一个元素。
迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束。
使用iter()定义迭代器,使用next()访问迭代器的下一个元素。当迭代器中没有下一个元素时,继续使用next()则会抛出StopIteration异常。
#Author:TiMax Liu
import sys
#声明迭代器两种方式
iter1 = [1,2,3,4,5].__iter__()
iter2 =iter([1,2,3,4,5])
#输出迭代器的内存地址
print(iter1, "\n", iter2)
#输出迭代器中元素
print(iter1.__next__(),"\n",iter2.__next__())
print('{0}\n{1}'.format(next(iter1),next(iter2)))
#遍历迭代器时,记得要使用try..exsccept捕获异常例:
while True:
try:
print(iter1.__next__())
except StopIteration:
print('超出元素个数!')
sys.exit()
可迭代对象
在python中并不是所有对象都是可迭代对象,可以使用isinstance('对象',Iterable),验证对象是否可迭代
#验证对象是否可迭代,使用Iterable需要先导入
from collections import Iterable
obj1 = [1,2,3].__iter__()
obj2 = '123'.__iter__()
obj3 = 000
print(isinstance(obj1,Iterable))#True
print(isinstance(obj2,Iterable))#True
print(isinstance(obj3,Iterable))#False
#验证是否为迭代器,使用Iterator需要先导入
from collections import Iterator
print(isinstance(obj2,Iterator))#True
print(isinstance(obj3,Iterator))#False
生成器
在 Python 中,使用了 yield 的函数被称为生成器(generator),由于每次开始都会从上次结束的位置开始,因此也是一个迭代器。
yield是一个语法糖,在调用生成器运行的过程中,每次遇到 yield 时函数会暂停并保存当前所有的运行信息,返回 yield 的值, 并在下一次执行 next() 方法时从当前位置继续运行。这种运用好处相对于使用一串很大的列表之类的需要开辟过大的内存单元,它在使用到多少才开辟多少。
#输出一个10位数导入斐波那契数列
def fibonacci(n):
a,b,counter = 0,1,0
while True:
if(counter > n):
return
yield a
a,b = b,a+b
counter += 1
f = fibonacci(10)
while True:
try:
print(f.__next__())
except StopIteration:
print('超出元素个数!')
break