python3.6生成器yield用法实例分析
作者:thormas1996 发布时间:2022-11-22 00:07:05
本文实例讲述了python3.6生成器yield用法。分享给大家供大家参考,具体如下:
今天看源码的时候看到了一个比较有意思的函数:yield
功能与return类似,都是返回定义的函数的一个结果,不同的是return返回后这次调用函数就结束了,除了返回值,其余临时变量都会被清除。而yield会停止在当前步,并保留其余变量的值,等下次调用该函数时,从yield的下一步继续往下运行。
yield的好处是如果函数需要很大的内存,比方说需要计算并返回一个很大的数列,如果用return,我们只能用一个list来存储每一步再输出,而用yield的话,只需要一个变量的内存即可,每次输出当前步的值,下次调用函数接着从这一步继续。
文字不太好说明,看一个很容易理解的例子:(python3.6)
我们定义一个函数test(),看看return的效果
def test(n):
for i in range(n):
return i
print('mark')
测试结果
for i in range(5):
print(test(3))
输出
0
0
0
0
0
每次调用函数时碰到return就自动结束了,返回当前i值
再来看看yield的效果:
def test2(n):
for i in range(n):
yield i
print('mark')
测试
for i in range(5):
print(test2(3))
输出
<generator object test2 at 0x12d245200>
<generator object test2 at 0x12d245200>
<generator object test2 at 0x12d245200>
只要函数中含有yield,python就会默认这个函数是一个生成器,这个测试相当于重复打开了三次生成器
生成器需要用next()
调用
测试
t = test2(3)
for i in range(3):
print('i=',i)
print(next(t))
next(t) 等同于 t.__next__()
结果
i= 0
0
i= 1
mark
1
i= 2
mark
2
可以看到,第一次返回i=0
之后,第二次再调用函数时,从yield i
的下一步继续,即print('mark')
。
生成器还支持用send()
将值传递进函数:
def test3():
value = (yield 1)
print(value)
print('mark1')
value = (yield value)
print(value)
print('mark2')
测试
t2 = test3()
print(t2.__next__())
print('-----------')
print(t2.send(2))
print('-----------')
print(t2.send(3))
输出
1
-----------
2
mark1
2
-----------
3
mark2
---------------------------------------------------------------------------
StopIteration Traceback (most recent call last)
<ipython-input-102-56e62df29d71> in <module>()
4 print(t2.send(2))
5 print('-----------')
----> 6 print(t2.send(3))StopIteration:
第一次next()返回1,并在当前停止,send(2)会将2传输给当前停止的那一步yield处,即相当于value = (yield 1)
变为value = (2)
然后继续运行
print(value)
print('mark1')
value = (yield value)
碰到yield再次停止,返回此时的vlue值2,之后send(3)
将3传输给当前停止那一步yield处,即第二个yield value
处,继续运行
print(value)
print('mark2')
生成器运行结束后生成StopIteration
希望本文所述对大家Python程序设计有所帮助。
来源:https://blog.csdn.net/thormas1996/article/details/80830266


猜你喜欢
- 本文最主要参考的是这一篇,后端也是用django来完成。大文件上传(秒传/断点续传)_使用Vue-Simple-Uploader插件 --V
- 项目中有这样的需求,通过IP地址判断客户端是网通的还是电信的。从同事那拿了个纯文本的IP纯真数据库,用Python写了一个小程序,感觉挺好的
- 一、前言在Python中,类表示具有相同属性和方法的对象的集合。在使用类时,需要先定义类,然后再创建类的实例,通过类的实例就可以访问类中的属
- 简介你手中的这本《JavaScript王者归来》不仅是一本传播知识的书,更是一本求道的书。本书分为五个部分循序渐进地与读者讨论了JavaSc
- 本文实例讲述了JavaScript使用setTimeout实现延迟弹出警告框的方法。分享给大家供大家参考。具体如下:先给大家展示一个延迟/定
- 1. 字符编码简介1.1. ASCIIASCII(American Standard Code for Information Interc
- 如果是感应触发.就选onmouseover如果是点击触发.就选onclick [把它们两互相替换,就可随时变为感应
- 效果图:搜索分类2种情况,一般的是当用户输入完,点击确定的按钮在向后发送请求,还有一种就是的我一边输入,一边向后台发送请求,但是会产生一个性
- 数据库状态 (database states)查询数据库的当前状态 :1、查询所有数据库的状态 ,通过sys.databases目录视图的s
- 一、renderer<meta name="renderer" content="webkit|ie-c
- 单继承时super()和__init__()实现的功能是类似的class Base(object):def __init__(self):p
- pytorch在数据中采用Dataset的数据保存方式,需要继承data.Dataset类,如果需要自己处理数据的话,需要实现两个基本方法。
- 大家好,学完面向对象与异常处理机制之后,接下里我们要学习 包与模块 。首先我们要了解什么是包?什么是模块?接下来我们还要学习 如何自定义创建
- pytorch 在torchvision包里面有很多的的打包好的数据集,例如minist,Imagenet-12,CIFAR10 和CIFA
- 本文介绍了手把手教你如何安装Pycharm,分享给大家,具体如下:1、首先去Pycharm官网,或者直接输入网址:http://www.je
- 复制目录: 包含多层子目录方法: 递归, 深度遍历,广度遍历深度遍历&广度遍历:思路:1.获得源目录子级目录,并设置目标目录的子级路
- 一。首先,添加如下存储过程CREATE PROCEDURE dbo.ChangeObjectOwner @Ol
- scrapy是目前python使用的最广泛的爬虫框架架构图如下解释:Scrapy Engine(引擎): 负责Spider、ItemPipe
- 双指数函数待拟合曲线为 y(x) = bepx + ceqximport matplotlib.pyplot as pltx = ([0.0
- 为什么要做这个?mock 第三方服务时,需要使用,另外包括自身开发,有时也会用到python#!/usr/bin/env python2#