目录
1.普通函数在函数体中写个yield,这个函数就变成了生成器
(1)send()获取下一个值的效果和next()基本一样,只是在获取下一个值的时候,会给上一个yield的位置传递一个数据
一、生成器的本质
迭代器
https://blog.csdn.net/g_optimistic/article/details/86510098
二、生成器的种类
1.生成器函数
2.生成器表达式
三、生成器函数
1.普通函数在函数体中写个yield,这个函数就变成了生成器
2.注意事项:
(1)生成器函数执行之后会得到一个生成器作为返回值,并不会执行函数体
(2)执行了__next__()内置方法以后,才会执行函数体,并且获得返回值
(3)next()方法,内部调用了生成器函数的__next__()方法
(4)yield,return 相同的是可以返回值,不同的是yield不会结束函数
3.yield 屈服了,暂停
注意:
next()函数有惰性,调一下,走一下,遇到yield停止
next(生成器) 等价于 生成器.__next__()
(1)创建一个函数,并且调用
def generator():
print('xxxx')
yield # 屈服了,暂停
print('zzzzz')
yield # 屈服了,暂停
ret = generator() # 调用生成器的时候,会返回一个生成器,用变量ret来接收这个生成器
ret.__next__() # 调用生成器的__next__(),菜户执行函数体
next(ret) # next(生成器) 等价于 生成器.__next__()
# xxxx
# zzzzz
# next()函数有惰性,调一下,走一下,遇到yield停止
(2)yield也可以有返回值
(3)创建生成器,定义多个yield值
(4)创建生成器,生成200桶康师傅方便面
4.send()方法
(1)send()获取下一个值的效果和next()基本一样,只是在获取下一个值的时候,会给上一个yield的位置传递一个数据
(2)使用send()的注意事项:
1)第一次使用生成器的时候,是用next()获取下一个值
2)最后一次yield不能接受外部的值
(3)练习:计算移动的平均值
def fun_avg():
count = 1
avg = 0
total = 0
while True:
get_num = yield avg
total += get_num
avg = total / count
count += 1
g = fun_avg()
print(next(g)) # 0
print(g.send(10)) # 10.0
print(g.send(20)) # 15.0
print(g.send(30)) # 20.0
5.yield from
使用for环取出g1生成器值的所有值
使用yield取出生成器的值
def generator():
yield from range(3)
yield from 'ab'
g1 = generator()
for gg in g1:
print(gg)
# 0
# 1
# 2
# a
# b
四、生成器表达式
1.格式
将列表推导式的[ ]改成()即可
# 列表推导式:
lst = [i for i in range(10)]
print(lst) # [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
# 生成器表达式:
g = (i for i in range(10))
for i in g:
print(i)
# 0
# 1
# 2
# 3
# 4
# 5
# 6
# 7
# 8
# 9
2.练习:老母鸡下蛋
# 1.列表推导式
egg_lst = ['鸡蛋%s' % i for i in range(10)]
print(egg_lst)
# ['鸡蛋0', '鸡蛋1', '鸡蛋2', '鸡蛋3', '鸡蛋4', '鸡蛋5', '鸡蛋6', '鸡蛋7', '鸡蛋8', '鸡蛋9']
# 2.生成器表达式
laomuji = ('鸡蛋%s' % i for i in range(10))
for i in laomuji:
print(i)
# 鸡蛋0
# 鸡蛋1
# 鸡蛋2
# 鸡蛋3
# 鸡蛋4
# 鸡蛋5
# 鸡蛋6
# 鸡蛋7
# 鸡蛋8
# 鸡蛋9
laomuji = ('鸡蛋%s' % i for i in range(10))
print(list(laomuji))
# ['鸡蛋0', '鸡蛋1', '鸡蛋2', '鸡蛋3', '鸡蛋4', '鸡蛋5', '鸡蛋6', '鸡蛋7', '鸡蛋8', '鸡蛋9']
# list()函数:底层会默认调用生成器的__next__()方法
注意:list()函数:底层会默认调用__next__()方法