上第一个实例:

def foo():
    print("starting...")
    yield 4
print(foo())

按照逻辑,应该输出starting, 但是实际上看下打印结果:

python之yield_Python

也就是说,这个函数根本不会执行

如何让这个函数执行呢?,看下个例子

def foo():
    print("starting...")
    yield 4
g = foo()
next(g)

原来需要调用next,才能正在让有yield的函数执行,那我们再调用一个next看下效果

def foo():
    print("starting...")
    yield 4
g = foo()
next(g)
next(g)

程序崩溃

python之yield_python_02

 再把上面的例子修改一下

def foo():
    print("starting...")
    yield 4
    print("ending...")
    yield 5
g = foo()
next(g)
next(g)

现在就不会崩溃了,输出如下:

python之yield_python_03

 ***********************总结********************

含有yield的函数需要调用next才能执行,第一个next执行到函数的第一个yield位置,第二个next从第一个yield执行后面开始执行。

*****************************************************

再把例子修改一下

def foo():
    print("starting...")
    res =yield 4
    print("ending...",res)
    res =yield 5
g = foo()
print(next(g))
print(next(g))

看下输出结果:

python之yield_python_04

 为什么res为none呢?这里需要引入一个send函数,可以给res赋值,不然就一直未null

def foo():
    print("starting...")
    res =yield 4
    print("ending...",res)
    res =yield 5
g = foo()
g.send(None)
g.send(256)

send函数作用和next一样,但是可以发送一个值给res,第一次记得发送None。运行结果如下:

python之yield_Python_05

 ***************************再看一个例子********************************************

def foo():
    print("starting...")
    res =yield 4
    print("ending...",res)
    res =yield 5
for aa in foo():
    print(aa)

 

 输出结果如下:

python之yield_python_06

 我们会发现没有next和send,居然也能执行下去,是不是很神奇

这里如果是for 。。in 这种模式,会自动执行next直到运行结束。。记住即可。