首页 > 代码库 > python基础-------迭代器,生成器,协程函数

python基础-------迭代器,生成器,协程函数

1,迭代器协议:

1.1 迭代器协议是指:对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个StopIteration异常,以终止迭代 (只能往后走不能往前退)

1.2. 可迭代对象:实现了迭代器协议的对象(如何实现:对象内部定义一个__iter__()方法)

1.3. 协议是一种约定,可迭代对象实现了迭代器协议,python的内部工具(如for循环,sum,min,max函数等)使用迭代器协议访问对象

2,迭代器:

1.1:为什么要用迭代器:

1.2 优点:迭代器提供了一种不依赖索引的取值方式,这样就可以遍历那些没有索引的可迭代对象,如:(字典,集合,文件)

            迭代器于列表比较,迭代器属于惰性计算,更省内存。

1.3 缺点:无法获取迭代器的长度,不如列表操作灵活。一次性的取值,只能从前向后取值,不能从后向前取值。

1.4 可迭代的,只要对象本身有__iter__方法,得到的就是迭代器。

1.5 列表list,元组tuple,字典dict,集合set,字符串str,文件file,都是可以迭代的。

 

1.6 示例:笨方法

d = {"a":1,"b":2,"c":3,}
i = d.__iter__()   #把字典变成一个可迭代的对象,i 就是迭代器
print(i.__next__())
print(i.__next__())
print(i.__next__())

1.7 运行结果:把字典里的k都打印出来了

 

1.8 用while来遍历字典:

d = {"a":1,"b":2,"c":3,}
i = d.__iter__()
while True:
    print(i.__next__())

 

1.9 运行结果字典可k全部打印出来了,但是,while是一个死循环,遍历玩字典里的三个k,就抛出了StopIteration异常,我们这样处理就好了

a
Traceback (most recent call last):
b
c
  File "F:/PycharmProjects/py_fullstack_s4/day23/迭代器.py", line 4, in <module>
    print(i.__next__())
StopIteration

 

2.0  把代码改成这样:

d = {"a":1,"b":2,"c":3,}
i = d.__iter__()
while True:
    try:
        print(i.__next__())
    except StopIteration:
        break

 

2.1 try ,except 是去除异常的语句,运行结果如下:

a
b
c

 

2.2 用 for 循环来遍历:

d = {"a":1,"b":2,"c":3,}

for k in d:
    print(k)

2.3 因为for 是非常牛逼的,他自己只接把d转成迭代器了,运行结果就是,a,b,c,

 

2.4 查看可迭代对象与迭代器对象:

s = "hello world"                                  #字符串 str
l = ["h","e","l","l""o"]                #列表 list
t = ("w","o","r","l","d")                          #元组 tuble
d = {"name":"gaoyuan","job":"IT","age":25}         #字典 dict
set1 = {1,2,3,4,5,}                                #集合 set
f = open("a.txt")                                  #文件 file

#都是可迭代的:都有__iter__方法
# s.__iter__()
# l.__iter__()
# t.__iter__()
# d.__iter__()
# set1.__iter__()
# f.__iter__()
print(isinstance(s,Iterable))
print(isinstance(l,Iterable))
print(isinstance(t,Iterable))
print(isinstance(d,Iterable))
print(isinstance(set1,Iterable))
print(isinstance(f,Iterable))
#返回的结果都是True  

#查看是否是迭代器 ,只有文件有__next__方法,
f.__next__()

print(isinstance(s,Iterator))  #False
print(isinstance(l,Iterator))   #False
print(isinstance(t,Iterator))   #False
print(isinstance(d,Iterator))   #False
print(isinstance(set1,Iterator))#False
print(isinstance(f,Iterator))      #True
#只有文件是迭代器

3,生成器:

 

3.1 什么是生成器?

可以理解为一种数据类型,这种数据类型自动实现了迭代器协议(其他的数据类型需要调用自己内置的__iter__方法),所以生成器就是可迭代对象

生成器分类及在python中的表现形式:(Python有两种不同的方式提供生成器)

生成器就是一个函数,函数体内含有yield关键字 就是生成器

return跟yield的区别

return返回一次值就彻底结束了,yield能返回多次值

1.生成器函数:常规函数定义,但是,使用yield语句而不是return语句返回结果。yield语句一次返回一个结果,在每个结果中间,挂起函数的状态,以便下次重它离开的地方继续执行

2.生成器表达式:类似于列表推导,但是,生成器返回按需产生结果的一个对象,而不是一次构建一个结果列表

 

3.2 为何使用生成器之生成器的优点

3.3 Python使用生成器对延迟操作提供了支持。所谓延迟操作,是指在需要的时候才产生结果,而不是立即产生结果。这也是生成器的主要好处。

 

3.4 生成器小结:

3.4.1.是可迭代对象

3.4.2.实现了延迟计算,省内存啊

3.4.3.生成器本质和其他的数据类型一样,都是实现了迭代器协议,只不过生成器附加了一个延迟计算省内存的好处,其余的可迭代对象可没有这点好处,记住喽!!!

 

 

 

 

 

 

 

 

 

 

 

 

 

 

python基础-------迭代器,生成器,协程函数