建立生成器的方法:python
1.经过生成器函数 ( yield)函数
2.生成器表达式spa
def func1(x): sum = 0 for i in range(1,x): x += 1 yield x g = func1(6) #生成器函数对
print(g) # <generator object func1 at 0x0000025E5D618780> #表示这是一个迭代器
print(g.__next__()) #一个next对应一个yield
print(g.__next__())
print(g.__next__())
print(g.__next__())
print(g.__next__()) #7 8 9 10 11
#yiedld 将值返回给生成器对象.__next__()
yield 的做用:1.一个next对应一个yieldcode
2.yield将值返回给生成器对象.__next__()对象
return的做用是结束函数,给函数的执行者返回值blog
yield 不会结束函数,一个next对应一个yield,给__next__()返回值内存
区别1:自定制的区别generator
l1 = [1,2,4] l2 = l1.__iter__() def func1(x): x += 1 yield x x += 2 yield x x += 3 yield x g = func1(5) print(g.__next__()) print(g.__next__())
区别2:内存级别的区别it
迭代器是须要将可迭代对象进行转化,可迭代对象很是占内存class
生成器是直接建立,不须要转化,从本质上就节省内存
send与nxet同样,也是对生成器取值(执行一个yield)的方法
send 能够给上一个yield 进行传值
第一次取值永远都是next
最后一个yield 永远也得不到send传的值
循环模式 :[变量(加工后的变量) for 变量 in iterable(可迭代对象)]
l1 = [i for i in range(1,10)] print(l1) #[1, 2, 3, 4, 5, 6, 7, 8, 9]
筛选模式 :[变量(加工后的变量)for 变量 in iterable(可迭代对象)if 条件]
l2 = [i for i in range(1,10) if i%2 ==0] print(l2) #[2, 4, 6, 8]
列表推导式优势:一行解决,方便
缺点:容易着迷,不易拍错,不能超过三次循环
列表推导式不能解决全部的列表的问题,全部不要太刻意使用
l1 = ( i for i in range(1,1000000)) print(l1.__next__()) #1 print(l1.__next__()) #2 print(l1.__next__()) print(l1.__next__()) print(l1.__next__()) #5 #能够经过循环打印必定数量的取值
mcase = {"a":10,"b":35} mcase_frequency = {mcase[k]:k for k in mcase} print(mcase_frequency) #{10: 'a', 35: 'b'}
sq = {x**2 for x in range(-5,6)} print(sq) #{0, 1, 4, 9, 16, 25} #自带去重功能