Python生成器next方法和send方法区别详解
yield的语法规则是:
在yield这里暂停函数执行,并返回yield后面表达式的值(默认为None),直到被next()再次调用时,从上次暂停的yield代码处继续往下执行。当没有可继续next()时,抛出异常,该异常可被for循环处理。
def fib(n):
def fib(n):
a, b = 0, 1
i = 0
while i < n:
yield b
a, b = b, a+b
i += 1
if __name__ == '__main__':
f = fib(10)
for item in f:
print(item)
python中,含有yield关键字的对象就是一个生成器,每次调用next方法时会执行到yield后面的语句,然后返回yield后面代码块的执行结果
def foo():
bar_a = yield 1 # bar_a是语句块(yield 1)的返回值,默认为None
bar_b = yield bar_a
yield "最后一个值,再迭代就要报StopIteration了"
f = foo() # 创建生成器,此时没有执行foo()里的任何语句
print(next(f)) # 从foo()里进入,一直执行到(yield 1)处,此时变量bar_a还没有创建
print(next(f)) # 先将语句块(yield 1)的返回值赋值个bar_a,此时bar_a的值是None。
# 然后执行到语句块(yield bar_a),bar_b也还没有被创建
print(next(f)
>>>1
>>>None
>>>最后一个值,再迭代就要报StopIteration了
send()
def foo():
bar_a = yield 1
bar_b = yield bar_a
yield "最后一个值,再迭代就要报StopIteration了"
f = foo()
print(f.send(None)) # 和next(f)的效果一模一样
print(f.send("my lover")) # 覆盖yield 1语句的返回值
print(next(f))
>>>1
>>>my lover
>>>最后一个值,再迭代就要报StopIteration了
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
Python face_recognition实现AI识别图片中的人物
最近碰到了照片识别的场景,正好使用了face_recognition项目,给大家分享分享。face_recognition项目能做的很多,人脸检测功能也是有的,是一个比较成熟的项目。感兴趣的可以了解一下2022-01-01
Python fire模块(最简化命令行生成工具)的使用教程详解
Python Fire是谷歌开源的一个第三方库,用于从任何Python对象自动生成命令行接口(CLI),可用于如快速拓展成命令行等形式。本文将通过实例为大家详细说说fire模块的使用,感兴趣的可以了解一下2022-10-10
torch.optim优化算法理解之optim.Adam()解读
这篇文章主要介绍了torch.optim优化算法理解之optim.Adam()解读,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-11-11
使用 Celery Once 来防止 Celery 重复执行同一个任务
这篇文章主要介绍了使用 Celery Once 来防止 Celery 重复执行同一个任务,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-10-10
让python json encode datetime类型
python2.6+ 自带的json模块,不支持datetime的json encode,每次都需要手动转为字符串,很累人,我们可以自己封装一个简单的方法处理此问题。2010-12-12


最新评论