列表生成式写法:
  [ i*2 for i in range(10) ]
也可以带函数
  [ fun(i) for i in range(10) ] 生成器:一边循环一边计算的机制称为生成器。在常用函数中,使用yield语句来返回结果,一次只返回一个结果。(可以节省内存,只有在调用的时候才会生成相应的数据 )
特点:只记录当前的位置,只有一个__next__()方法。
和列表的区别:生成器只有在调用的时候才会生成。
生成器表达式:同列表解析语法,只不过是把列表解析的[]换成()
比如:
l = [ x*x for x in range(10)]
g = ( x*x for x in range(10))
这里:l就是一个列表,g是一个生成器
生成器的打印方法:1:使用__next__()函数(python3),2:使用for循环
赋值语句:a,b = b,a+b 相当于 t=(b,a+b) 为a=t[0],b=t[1]
实例:斐波纳契数列:除第一个和第二个数外,任意一个数都可由前2个数相加得到。
def fib(max):
n,a,b = 0,0,1
while n < max:
#print(b)
yield b
a,b = b,a+b
n += 1
#return 'done'
f = fib(100)
print('sfsfsd')
f.__next__() 使用生成器后,不会出现停顿,实现程序外部随时调用函数的值 yield 通过在单线程下实现并发运算的效果
send方法:唤醒并同时给yield 传值
next方法:只唤醒yield
生成器特点:

生成器唯一注意的事项:生成器只能遍历一次。

迭代对象:可以直接作用于for循环的对象统称为可迭代对象。(iterable) 如:列表,字典,集合等,还有生成器
迭代器:可以被next()函数调用要么返回下一个值,要么引起StopIteration异常的对象称为迭代器:iterator
内置方法:isinstance()方法可以判断一个对象是否是可迭代对象。
可迭代对象都可以通过:iter()函数变为迭代器iterator
a = [1,2,3]
b = iter(a)
print(b.__next__())
print(b.__next__())
迭代器的计算属于惰性计算,就是在需要返回下一个值时才会计算。
迭代器可以表示一个无限大的数据流。(如全体自然数)列表是则是不可以。
举例:
#首先获得迭代器(iterator)对象
it = iter([1,2,3,4,5])
while True:
try:
#获得下一个值
x = next(it)
export StopIteration:
# 遇到StopIteration就退出循环
break 举例:用生成器实现吃包子(基本的生产者/消费者模型)
 def consumer(name):  # 消费者
print(' %s 准备吃包子' % (name))
while True:
baozi = yield
print('%s 包子来了, %s 吃包子' % (baozi,name)) def producer(name): # 生产者
c1 = consumer('jack')
c2 = consumer('Anne')
c1.__next__()
c2.__next__()
print('%s 开始做包子........' % name)
for i in range(10):
time.sleep(1)
print('%s 做完2个包子' % name)
c1.send(i)
c2.send(i) # 执行生产者
producer('vivi')

举例:使用生成器生成进度条

def show_process(total):
"""使用生成器打印进度条"""
curr = 0
percent = 0
print('开始打印进度条')
while curr <= total:
if int((curr / total) * 100) > percent:
sys.stdout.write('#'*curr + '%s%%' % curr + '\r')
sys.stdout.flush()
percent = int((curr / total) * 100)
new_size = yield
curr += new_size x = show_process(100)
x.__next__()
for i in range(1,101):
x.send(1)

  

python学习之- 生成器/迭代器的更多相关文章

  1. python高级之生成器&迭代器

    python高级之生成器&迭代器 本机内容 概念梳理 容器 可迭代对象 迭代器 for循环内部实现 生成器 1.概念梳理 容器(container):多个元素组织在一起的数据结构 可迭代对象( ...

  2. 第三篇:python高级之生成器&迭代器

    python高级之生成器&迭代器   python高级之生成器&迭代器 本机内容 概念梳理 容器 可迭代对象 迭代器 for循环内部实现 生成器 1.概念梳理 容器(container ...

  3. Python学习---装饰器/迭代器/生成器的学习【all】

    Python学习---装饰器的学习1210 Python学习---生成器的学习1210 Python学习---迭代器学习1210

  4. python学习笔记(5)--迭代器,生成器,装饰器,常用模块,序列化

    生成器 在Python中,一边循环一边计算的机制,称为生成器:generator. 如: >>> g = (x * x for xin range(10)) >>> ...

  5. Python学习二(生成器和八皇后算法)

    看书看到迭代器和生成器了,一般的使用是没什么问题的,不过很多时候并不能用的很习惯 书中例举了经典的八皇后问题,作为一个程序员怎么能够放过做题的机会呢,于是乎先自己来一遍,于是有了下面这个ugly的代码 ...

  6. python学习-39 生成器总结

    总结 1.语法上和函数类似:生成器函数和常规函数几乎是一样的.它们都是使用def语句进行定义,差别在于,生成器使用yield语句返回一个值,常规函数使用return语句返回一个值. 2.自动实现迭代器 ...

  7. python学习之生成器

    4.6 生成器Generrator ​ 生成器本质就是迭代器.python社区生成器与迭代器是一种. ​ 生成器与迭代器的唯一区别:生成器是我们自己用python代码构建的 4.6.1生成器初识 py ...

  8. Python学习之路——迭代器

    迭代器 # 通过迭代器取值优缺点: # 优点:不依赖索引,完成取值 # 缺点:不能计算长度,不能指定位取值(只能从前往后逐一取值) 可迭代对象 ''' 可迭代对象: 有__iter__()方法的对象, ...

  9. python学习笔记四 迭代器,生成器,装饰器(基础篇)

    迭代器 __iter__方法返回一个迭代器,它是具有__next__方法的对象.在调用__next__方法时,迭代器会返回它的下一个值,若__next__方法调用迭代器 没有值返回,就会引发一个Sto ...

随机推荐

  1. DDR SDRAM

    DDR SDRAM(Double Data Rate SDRAM)是一种高速CMOS.动态随机访问存储器, 它采用双倍数据速率结构来完成高速操作.应用在高速信号处理系统中, 需要缓存高速.大量的数据的 ...

  2. oid和节点名称

    由于单篇文档最大字限制是40000个字符,不能将OID附上,因此写出我是如何得到这些OID的. 1.安装NET-SNMP yum install net-snmp yum install net-sn ...

  3. 洛谷 P1454 圣诞夜的极光 == codevs 1293 送给圣诞夜的极光

    题目背景 圣诞夜系列~~ 题目描述 圣诞老人回到了北极圣诞区,已经快到12点了.也就是说极光表演要开始了.这里的极光不是极地特有的自然极光景象.而是圣诞老人主持的人造极光. 轰隆隆……烟花响起(来自中 ...

  4. Hadoop 常用命令之 HDFS命令

    命令 说明 hadoop fs -mkdir 创建HDFS目录 hadoop fs -ls 列出HDFS目录 hadoop fs -copyFromLocal 使用-copyFromLocal 复制本 ...

  5. 深度剖析 MySQL 事务隔离

    概述 今天主要分享下MySQL事务隔离级别的实现原理,因为只有InnoDB支持事务,所以这里的事务隔离级别是指InnoDB下的事务隔离级别. 隔离级别 读未提交:一个事务可以读取到另一个事务未提交的修 ...

  6. 部署 k8s Cluster(上)[转]

    我们将部署三个节点的 Kubernetes Cluster. k8s-master 是 Master,k8s-node1 和 k8s-node2 是 Node. 所有节点的操作系统均为 Ubuntu ...

  7. python基础一 day9 函数升阶(2)

    def max(a,b): return a if a>b else bprint(max(1, 2)) # 函数进阶# a = 1# def func():# print(a)# func() ...

  8. 二分+贪心 || CodeForces 551C GukiZ hates Boxes

    N堆石头排成一列,每堆有Ai个石子.有M个学生来将所有石头搬走.一开始所有学生都在原点, 每秒钟每个学生都可以在原地搬走一块石头,或者向前移动一格距离,求搬走所有石头的最短时间. *解法:二分答案x( ...

  9. HTML中pre标签的用法

    我们经常会在要保持文本格式的时候使用pre标签,比如当我们要展示源代码的时候,只要放一个pre标签,然后把源代码直接复制,粘贴,然后在页面上就可以保持好格式.不会像放在其它标签里那样,把换行和空格都自 ...

  10. [LUOGU] P3469 [POI2008]BLO-Blockade

    https://www.luogu.org/problemnew/show/P3469 求无向图分别删去每个点后不连通的点对数. 首先,对于任何一个点,它本身删了,就会和剩下的n-1个点不连通,点对是 ...