详解 Python 中的 yield from 语法
转载请注明出处:https://blog.csdn.net/jpch89/article/details/87776528
0. 参考资料
1. 语法和语义描述
yield from <expr>
这种表达式语法可以出现在一个生成器内部。
其中 <expr>
必须是一个可迭代对象,我们从中获取迭代器。
迭代器会运行直至元素耗尽,在此过程中,它直接从包含 yield from
表达式的生成器(委派生成器 delegating generator
)的调用方 caller
获取值,并向其生成值。
此外,当该迭代器是另一个生成器的时候,子生成器可以执行 return
语句,该语句的值会成为 yield from
表达式的值。
yield from
表达式的完整语义如下:
- 迭代器生成的任何值都会直接传给调用方
- 通过
send
发送给委派生成器的值会直接传给迭代器。如果发送的值为None
,会调用迭代器的__next__()
方法。如果发送的值不是None
,会调用迭代器的send()
方法。如果调用时抛出了StopIteration
异常,委派生成器恢复运行。任何其他的异常会向上传播给委派生成器。 throw
给委派生成器的异常中,除了GeneratorExit
异常,都会传递给迭代器的throw()
方法。如果调用抛出StopIteration
,委派生成器恢复运行。任何其他的异常会向上传播给委派生成器。- 如果向委派生成器
throw
了GeneratorExit
异常,或者调用了委派生成器的close()
方法,则会调用迭代器的close()
方法(如果它有的话)。如果调用导致异常,它会向上传播给委派生成器。否则,委派生成器自身抛出GeneratorExit
异常。 yield from
表达式的值是迭代器终止时抛出的StopIteration
异常的第一个参数。- 生成器中的
return expr
会在生成器退出的时候抛出StopIteration(expr)
异常。
2. 扩展了 StopIteration
为了方便,StopIteration
异常被赋予一个 value
属性,它会存储 StopIteration
的第一个参数,如果没有参数,则为 None
。
3. 等价代码
RESULT = yield from EXPR
变量说明:
_i
子生成器_y
子生成器产出的值_r
最终结果,即子生成器运行结束后yield from
表达式的值_s
发送的值,调用方发给委派生成器的值,这个值会转发给子生成器_e
异常对象
RESULT = yield from EXPR
在语义上与下面的代码等价: