今天主要学习了
1.生成器
2.生成器函数
3.各种推导式(比较诡异,理解了很简单,不理解很难)
4.生成器表达式(重点)
一.生成器
def func(): print'我叫周润发' return '林志玲' #return在函数中表示返回的意思 set=func() print(set)
这里的set 就是创建了一个生成器 注意: (大坑) 生成器函数运行之后,产生了一个生成器,而不是执行函数
本质就是个迭代器 ,一个一个的创建对象
创建生成器的方法 :
1.生成器函数
2. 通过生成器表达式来获取生成器
3. 类型转换 (前期基本上看不到,后期才接触)
二 .生成器函数 :
生成器函数中包含了yield ,返回数据和return差不多 ,但是yield不会终止函数,
yield : 可以分段执行一个函数
return : 执行后会立即结束这个函数的执行
生成器函数会在执行的时候返回生成器 ,而不是执行此函数
能够向下执行的2个条件 :
1 . __next__() 执行到下一个yield
2. send() ,执行到下一个yield ,给上一个yield位置传递一个值
所有的生成器都是可迭代的 ,也就是说都可以直接使用for循环
都可以使用list()函数来获取到生成器内所有的数据 .
生成器中记录的是代码而不是函数的运行
def func(): print'我的天啊' yield '天呐' gen=func() # 创建生成器. 此时运行会把生成器函数中的代码记录在内存 ,当执行到__next__(),
运行此空间中的代码,运行到yield结束.
生成器函数的特点:
优点: 节省内存 , 生成器本身就是代码,几乎不占用内存
特点: 惰性机制 ,只能向前,不能后退
三 .各种推导式
列表的推导式 lis=[结果 for循环 if条件]
# 想知道老男孩一共开了多少期 lst=['python%s期'%i for i in range(1,19)] print(lst) # 生成列表.类表中装的数据是 1-100之间所有的偶数的平方 lst=[i**2 for i in range(1,101) if i%2==0] print(lst)
字典的推导式 dic={结果(k:v) for循环 if条件}
dic= {"主食": "炒面", "副食": "小拌菜", "汤":"疙瘩汤"} # 把字典的key和value互换, 生成新字典 d={v,k for k,v in dic.items()} print(d)
集合的推导式 set={结果(k) for循环 if条件}
集合的推导式和字典一样 ,只不过字典返回的值有k,v ,而集合只有一个返回值
注 : 元组没有推导式
四 .生成器表达式 (重点)
(结果 for循环 if条件)
g=(结果 for i in range(10)) print(g) #<generator object <genexpr> at 0x0000000009E573B8> g=(i for i in range(10) ) #生成器表达式
# 生成器函数 # def func(): # print(111) # yield 222 # # #提示: 惰性机制, 只能向前 # g = func() # 创建生成器 # g1 = (i for i in g) # 生成器表达式 # g2 = (i for i in g1) # 生成器表达式 # # # # print(list(g)) #list 里面有__next__一次性将func中的内容全部拿空 # print(list(g1)) # for -> __next__() # print(list(g2)) 结果 [222] [] [] #原因 : g已经将func的内容拿空了,g1 ,g2在想拿的时候已经没有了,
所以为空列表