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在想拿的时候已经没有了,
所以为空列表
day12 生成器和各种推导式的更多相关文章
- python基础学习Day12 生成器、列表推导式、字典的表达式、字典键值对的互换、集合推导式
一.生成器 1.1 生成器:就是(python)自己用代码写的迭代器,生成器的本质就是迭代器. 1.2 生成器函数 def func1(x): x += print() yield x print() ...
- Python进阶(四)----生成器、列表推导式、生成器推导式、匿名函数和内置函数
Python进阶(四)----生成器.列表推导式.生成器推导式.匿名函数和内置函数 一丶生成器 本质: 就是迭代器 生成器产生的方式: 1.生成器函数
- Python-02 生成器表达式,列表推导式
列表推导式和生成器表达式 列表推导式,生成器表达式1,列表推导式比较直观,占内存2,生成器表达式不容易看出内容,省内存. [ 变量(加工后的数据) for 变量i in 可迭代的数据类型 ] 列表 ...
- python之生成器和列表推导式
一.生成器函数 1.生成器 就是自己用python代码写的迭代器,生成器的本质就是迭代器(所以自带了__iter__方法和__next__方法,不需要我们去实现). 2.构建生成器的两种方式 1,生成 ...
- day14.生成器进阶,推导式
生成器中取值的三种方法 方法1:next() 方法2:for 循环 方法3:数据类型的强制转换 def func(): for i in range(20): yield '赛车*{}'.format ...
- 【python】 迭代器、生成器、列表推导式
一.可迭代对象.迭代器 1.可以被for循环的数据类型(可迭代对象): 字符串(str).列表(list).字典(dict).元祖(tuple).range() 2.迭代器 2.1 将可迭代对象==& ...
- Python_迭代器、生成器、列表推导式,生成器表达式
1.迭代器 (1)可迭代对象 s1 = ' for i in s1: print(i) 可迭代对象 示例结果: D:\Python36\python.exe "E:/Python/课堂视频/ ...
- python 生成器和各种推导式
##################################总结############################### 什么是迭代器? 可迭代对象通过__iter__()可以转换成迭代 ...
- python全栈开发day13-迭代器、生成器、列表推导式等
昨日内容:函数的有用信息.带参数的装饰器.多个装饰器修饰一个函数 迭代器 可迭代对象:内部含有__iter__方法 迭代器 定义:可迭代对象.__iter__()就是迭代器,含有__iter__且__ ...
随机推荐
- 消息队列rabitMq
rabbitmq MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它们.消息 ...
- python中的异常处理tryexcept
1.异常基础 在编程过程中为了增加友好性,在程序出现bug时一般不会将错误信息显示给用户,而是现实一个提示的页面,通俗来说就是不让用户看见大黄页!!! 2.异常种类 names = ['张三','李四 ...
- (4)进程---daemon守护线程和join阻塞
join ()方法:主线程A中,创建了子线程B,并且在主线程A中调用了B.join(),那么,主线程A会在调用的地方等待,直到子线程B完成操作后,才可以接着往下执行,那么在调用这个线程时可以使用被调用 ...
- 《HTTP 权威指南》笔记:第十三章 摘要认证体制
前言 基本认证存在缺陷,摘要认证为了解决基本认知的一些缺陷,进行了进一步的完善,更加安全. 流程 摘要认证的特点是:永远不会以明文方式在网络上发送密码原理:通过发送一个「指纹」或者「密码的摘要」来验证 ...
- js新打开页面
var a = document.createElement("a"); a.setAttribute("href", href); a.setAttribut ...
- hdu-3366 Passage 概率DP 读懂就能AC hhh
http://acm.split.hdu.edu.cn/showproblem.php?pid=3366 读题的时候没发现这个P Q 1-P-Q是全集的划分,以为是独立事件,写错了转移方程233 先贪 ...
- LCS(最长公共子序列)问题
例题见挑战程序设计竞赛P56 解释:子序列是从原序列中按顺序(可以跳着)抽取出来的,序列是不连续的,这是其和子串最大的区别: 我们可以定义dp数组为dp[i][j],表示的是s1-si和t1-ti对应 ...
- JavaScript工具函数集
/** * [getQueryStringArgs 用以解析查询字符串] * @return {[Object]} [一个包含所有参数的对象] */ function getQueryStringAr ...
- java的泛型与反射机制
什么是泛型? 泛型,即“参数化类型”.顾名思义,就是将类型由原来的具体的类型参数化,类似于方法中的变量参数,此时类型也定义成参数形式(可以称之为类型形参),然后在使用/调用时传入具体的类型(类型实参) ...
- oracle分区表(附带按照月自动分区、按天自动分区)
--list_range 示例 drop table list_range_tab purge; create table list_range_tab(n1 number,n2 date)pa ...