day12 生成器和各种推导式

今天主要学习了

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在想拿的时候已经没有了,
所以为空列表

  

上一篇:[转] JAVA的Random类


下一篇:C#7.2——编写安全高效的C#代码 c# 中模拟一个模式匹配及匹配值抽取 走进 LINQ 的世界 移除Excel工作表密码保护小工具含C#源代码 腾讯QQ会员中心g_tk32算法【C#版】