1. 生成器和生成器函数

生成器的本质就是迭代器
生成器的三种创建办法:
1.通过生成器函数
2.通过生成器表达式创建生成器
3.通过数据转换
 

2. 生成器函数:

函数中包含了yield的就是生成器函数

注意:生成器函数被执行. 获取到的是生成器. 而不是函数的执行生成器表达式:

(结果 for 变量 in 可迭代对象 if 筛选)

取值:

1. __next__()

 def func():
     print("我是周杰伦")
     yield "昆凌"  # 函数中包含了yield, 当前这个函数就不再是普通的函数了. 是生成器函数

 g = func()
 print(g.__next__())
 print(func().__next__())

 g1 = func()
 g2 = func()
 print(g1.__next__())
 print(g1.__next__())

 print("==============")
 print(g2.__next__())

 g = func()  # 通过函数func()来创建一个生成器
 print(g.__next__()) # 周杰伦
 print(g.__next__()) # 王力宏
 print(g.__next__()) # 笛卡尔积
 print(g.__next__())

 # return 直接返回结果. 结束函数的调用
 # yield 返回结果.可以让函数分段执行
 #
 def func():
     lst = []
     for i in range(1,100001):
         lst.append("衣服%s" % i)
     return lst

 def gen():
     i = 1
     while i < 100001:
         yield "衣服%s" % i
         i = i + 1
 g = gen()
 print(g.__next__())
 print(g.__next__())
 print(g.__next__())
 print(g.__next__())
 print(g.__next__())
 print(g.__next__())

 def func():
     yield 11
     yield 22
     yield 33
     yield 44

 g = func()  # 拿到的是生成器. 生成器的本质是迭代器. 迭代器可以被迭代 生成器可以直接for循环

 for i in g:
     print(i)    # 本质上执行的是__next__()

 it = g.__iter__()
 while True:
     try:
         print(it.__next__())
     except StopIteration:
         break

2. send(值) 给上一个yield位置传一个值, 第一个和最后一个yield不用传值

 def func():
     print("大碴粥")
     a = "
     print(a)
     print("狗不理")
     b = "
     print(b)
     print("大麻花")
     c = "
     print(c)

 g = func()
 print(g.__next__())
 print(g.send(1))
 print(g.send(2))
 print(g.send(3))

 # __next__() 可以让生成器向下执行一次
 # send() 也可以让生成器向下执行一次, 给上一个yield传一个值, 第一个不能用send(). 最后一个也不要传值

 def eat():
     print("我吃什么啊")
     a =  yield  "馒头"
     print("a=",a)
     b =  yield  "大饼"
     print("b=",b)
     c =  yield  "韭菜盒子"
     print("c=",c)
     yield  "GAME OVER"

 gen = eat()      # 获取⽣成器

 ret1 = gen. __next__ ()
 print(ret1)
 ret2 = gen.send("胡辣汤")
 print(ret2)
 ret3 = gen.send("狗粮")
 print(ret3)
 ret4 = gen.send("猫粮")
 print(ret4)

 def func():
     yield 11
     yield 22
     yield 33
     yield 44
 g = func()
 lst = list(g)   # 可迭代对象
 print(lst)
 3. 可以for循环
 
 4. list(g)
 

3. 各种推导式和生成器表达式:

 # 生成列表 里面装1-14的数据
 lst = []
 for i in range(1,15):
     lst.append("python%s" % i)
 print(lst)

 # 列表推倒式; 最终给你的是列表
 # 语法 [最终结果(变量) for 变量 in 可迭代对象]

 lst = [i for i in range(1,15)]
 print(lst)

 # [最终结果 for 变量 in 可迭代对象 if 条件]
 lst = [i for i in range(1,101) if i%2==0]
 print(lst)

 # 1. 获取1-100内能被3整除的数
 lst = [i for i in range(1,101) if i % 3 == 0]
 # 2. 100以内能被3整除的数的平方
 lst = [i*i for i in range(1,101) if i % 3 == 0]
 # 3. 寻找名字中带有两个e的⼈的名字
 names = [['Tom', 'Billy', 'Jefferson' , 'Andrew' , 'Wesley' , 'Steven' ,
 'Joe'],['Alice', 'Jill' , 'Ana', 'Wendy', 'Jennifer', 'Sherry' , 'Eva']]
 lst = [name for first in names for name in first if name.count("e") == 2]
 print(lst)

 lst = ["衣服%s" % i for i in range(10000)]
 g = (i for i in range(10))
 print(list(g))

 gen = ("麻花藤我第%s次爱你" % i for i in  range(10))
 for i in  gen:
     print(i)

生成器的惰性机制

def func():
    print(111)
    yield  222
g = func()
g1 = (i  for i in  g)
g2 = (i  for i in  g1)

print(list(g))
print(list(g1))
print(list(g2))

列表推倒式 [结果 for 变量 in 可迭代对象 if 筛选]

字典推倒式 {结果 for 变量 in 可迭代对象 if 筛选} 结果=>key:value

集合推倒式 {结果 for 变量 in 可迭代对象 if 筛选} 结果=>key

dic = {"a":"b", "c":"d"}
# 把字典中的key:value互换 .{"b":"a", "d":"c"}
new_dic = {dic[key]:key for key in dic}
print(new_dic)

lst1 = ["alex", "wusir", "taibai", "ritian"]
lst2 = ['sb', "很色", "很白", "很牛"]
# {"alex":"sb", "wusir":"很色"}

dic = { lst1[i]:lst2[i] for i in range(len(lst1))}
print(dic)

lst = ["马化腾", "马化腾", "王建忠", "张建忠", "张建忠", "张雪峰", "张雪峰"]

s = {i for i in lst}    # 集合推倒式
print(s)
05-11 17:21
查看更多