关于得带的基本使用方法,可以往上查一下。这里主要记录下在编码中可能遇到的报错,和处理方式。
import time
def func3():
for i in range(5):
yield i
while True:
a = next(func3())
print(a)
time.sleep(1)
如果使用上面这种取值方式,你会发现会一直循环获取迭代对象的第一个值。
0
0
0
原因就是每次获取的都是新的可迭代对象。
稍作修改后如下:
import time
def func3():
for i in range(5):
yield i
b = func3()
while True:
a = next(b)
print(a)
time.sleep(1)
结果是:
0
1
2
3
4
Traceback (most recent call last):
File "C:\Users\36905\PycharmProjects\TicketDowngrade\test\3.py", line 43, in <module>
a = next(b)
StopIteration
这样取值就是正常的。但是居然报错,这里是正常的,当取不到值时,就会通过报 StopIteration信号。
优化下代码:
import time
def func3():
for i in range(5):
yield i
b = func3()
while True:
try:
a = next(b)
except StopIteration:
break
print(a)
time.sleep(1)
这样结果就正常了。
更详细的原理处理过程可以参考:
关于python:yield如何捕获StopIteration异常? | 码农家园
注意:
而且编码的过程中发现,如果出现多层for循环或者参杂递归函数后的yield迭代逻辑,也会出现一些问题。
因为for循环本身具备迭代性,同样支持next方法。所以外部next调用的时候,会返回第一层for循环中的二次调用函数对象本身。可以通过再次next方法及next(next(func))来实现底层yield的调用。但这样带来的问题就是。你自己也搞不清楚拿到的到底是第几层的第几次调用,比较烧脑。有没有大神提供下好的方法或者解决方案。欢迎评论留言。这里先行感谢了。
未知蹊跷逻辑:
昨天在开发的过程中。在多层嵌套for循环后,我居然发现有写逻辑居然出现错误,if判断数值大小,居然失效,全是TRUE通过。除非添加else,否则一定通过if,这样我也很费解。而且不是偶发通过,是必然不做判断。不知道是python3.9.7的原因还是我电脑芯片架构有问题。有相同经历的,也可以告诉我原因。今天又试了下,居然又正常了。