python之yield表达式

Posted 流云轩

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python之yield表达式相关的知识,希望对你有一定的参考价值。

yield表达式用于generator function

调用generator function时,返回一个iterator(函数内语句不被会执行),调用iterator函数时,执行到yield表达式,

当前函数暂停执行,返回表达式的值到调用者,继续调用iterator函数,从暂停处恢复执行。、

遇到yield表达式,与遇到其他表达式差不多,yield表达式也有值,一般为None。

与其他表达式的不同之处在于yield表达式会在yield处返回表达式的值

官方文档描述如下:

    When a generator function is called, it returns an iterator known as a generator. That generator then controls the execution of the generator function. The execution starts when one of the generator’s methods is called. At that time, the execution proceeds to the first yield expression, where it is suspended again, returning the value of expression_list to the generator’s caller. By suspended, we mean that all local state is retained, including the current bindings of local variables, the instruction pointer, the internal evaluation stack, and the state of any exception handling. When the execution is resumed by calling one of the generator’s methods, the function can proceed exactly as if the yield expression were just another external call. The value of the yield expression after resuming depends on the method which resumed the execution. If __next__() is used (typically via either a for or the next() builtin) then the result is None. Otherwise, if send() is used, then the result will be the value passed in to that method.

    Yield expressions are allowed anywhere in a try construct. If the generator is not resumed before it is finalized (by reaching a zero reference count or by being garbage collected), the generator-iterator’s close() method will be called, allowing any pending finally clauses to execute.

    When the underlying iterator is complete, the value attribute of the raised StopIteration instance becomes the value of the yield expression. 

官方例子:

>>> def echo(value=None):
...     print("Execution starts when ‘next()‘ is called for the first time.")
...     try:
...         while True:
...             try:
...                 value = (yield value)
...             except Exception as e:
...                 value = e
...     finally:
...         print("Don‘t forget to clean up when ‘close()‘ is called.")
...
>>> generator = echo(1)
>>> print(next(generator))
Execution starts when next() is called for the first time.
1
>>> print(next(generator))
None
>>> print(generator.send(2))
2
>>> generator.throw(TypeError, "spam")
TypeError(spam,)
>>> generator.close()
Dont forget to clean up when close() is called.

模拟个iteratorrange函数

def my_range(start, stop=None, step=1):
    if not stop:
        stop = start
        start = 0
    while start < stop:
        yield start
        start += step


if __name__ == __main__:
    for i in my_range(10):
        print(i)
    for i in my_range(0, 10):
        print(i)
    for i in my_range(0, 10, 2):
        print(i)

 

以上是关于python之yield表达式的主要内容,如果未能解决你的问题,请参考以下文章

python之yield与装饰器

python yield学习

关于Python中的yield的理解

python之生成器和列表推导式

Python-yield 三元运算 Lambda表达式

Python:lambda表达式和yield关键字理解与使用讲解