一.可迭代对象
对象必须提供一个__iter__()方法,如果有,那么就是可迭代对象,
像列表,元祖,字典等都是可迭代对象
可使用isinstance(obj,Iterable)方法判断
 from collections import Iterable,Iterator
l={'':2,'fd':5,'f':6}
l_i=l.__iter__() print(isinstance(l,Iterable))
print(isinstance(l_i,Iterator))

结果:

True

True

二.迭代器

迭代器协议:
对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个StopIteration异常,以终止迭代 (只能往后走不能往前退)
符合迭代器协议的就是迭代器。
一个对象是迭代器也是可迭代对象
from collections import Iterable,Iterator
l={'2':2,'fd':5,'f':6}
l_i=l.__iter__()
s=isinstance(l,Iterable)
print(s)
print(isinstance(l_i,Iterator))
打印结果:
True
True
三.生成器
遵循迭代器协议,相当于一种特殊的迭代器对象
1.生成器表达式
(1)三元表达式(必须是三元)
name = '李'
res='儿子' if name == '李' else '爸爸'
print(res)
打印结果:
儿子
(2)列表解析
所谓列表解析就是列表内包含两元或三元表达式(不能是四元)
 l=['蚂蚁%s' %i for i in range(10)]
l1=['蚂蚁%s' %i for i in range(10) if i >5]
print(l)
print(l1)
打印结果:
['蚂蚁0', '蚂蚁1', '蚂蚁2', '蚂蚁3', '蚂蚁4', '蚂蚁5', '蚂蚁6', '蚂蚁7', '蚂蚁8', '蚂蚁9']
['蚂蚁6', '蚂蚁7', '蚂蚁8', '蚂蚁9']
一行代码写出9*9乘法表:
print('\n'.join([' '.join(["%dX%d=%-2d" %(i,m,m*i) for i in range(1,m+1)]) for m in range(1,10)]))
原理:.join()方法处理的结果是一个整体的字符串
(3)生成器表达式
  l=['蚂蚁%s' %i for i in range(10)]#列表
l=('蚂蚁%s' %i for i in range(10))#生成器表达式
和列表相比不占用内存,使用一次生成一次
l=('蚂蚁%s' %i for i in range(10))
print(l)
print(l.__next__())
print(l.__next__())
print(next(l))
print(next(l))
运行结果:
<generator object <genexpr> at 0x000002191AFB5BA0>
蚂蚁0
蚂蚁1
蚂蚁2
蚂蚁3 2.生成器函数
优点:
不会立即执行,节省内存。
有需要时用一个现运行出一个,yield会保留当前状态,下次从当前位置继续运行,直到再次碰到yeild。
对比两个过程理解:
过程一(做出一个卖一个,即调用一次现运行出来一个结果)
 def product_baozi():
for i in range(100):
print('正在生产包子%s' %i)
yield '一屉包子%s' %i #i=1
print('开始卖包子')
pro_g=product_baozi()
baozi1=pro_g.__next__()
运行结果:
正在生产包子0
过程二:(调用第二次,现运行出来第二个结果)
 def product_baozi():
for i in range(100):
print('正在生产包子%s' %i)
yield '一屉包子%s' %i #i=1
print('开始卖包子')
pro_g=product_baozi() baozi1=pro_g.__next__()
baozi1=pro_g.__next__()
打印结果:
正在生产包子0
开始卖包子
正在生产包子1
3.生成器特性
特性一:for循环可以遍历生成器
def eges():
for i in range(5):
yield '鸡蛋%s' %i #i=1
pro_g=eges() for i in pro_g:
print(i)
特性二:生成器只能迭代一次,用完就没了
 with open('人口普查','r',encoding='utf-8') as f:
def g_population():
for i in f:
yield i print(sum(eval(l)['population'] for l in g_population()))
print(g_population().__next__()) #此句会抛出异常
4.利用生成器实现单线程并发
send()方法,
有一个参数,该参数指定的是上一次被挂起的yield语句的返回值,
并且再次遇到yeild会向send传回一个值。
实例:饭店吃饭
 import time
def consetomer():
print('服务员点餐')
time.sleep(5)
for i in range(5):
cai=yield i #接受send的传值,并向下执行,直到结束或遇到下一个yield(此时的yield会向send传回一个值)
print('顾客开始吃第%s个菜' %cai) def canting():
g1=consetomer()
print(g1.__next__())
print('厨师准备做菜')
for i in range(1,5):
time.sleep(1)
print('第%s个菜做好了' %i)
print('第%s个好吃' %g1.send(i)) #传送上一次挂起的yield并等待接受下一次yeild返回值
canting()

 

打印结果:

 服务员点餐
0
厨师准备做菜
第1个菜做好了
顾客开始吃第1个菜
第1个好吃
第2个菜做好了
顾客开始吃第2个菜
第2个好吃
第3个菜做好了
顾客开始吃第3个菜
第3个好吃
第4个菜做好了
顾客开始吃第4个菜
第4个好吃
 

python(可迭代对象,迭代器,生成器及send方法详解)的更多相关文章

  1. python 可迭代对象 迭代器 生成器总结

    可迭代对象 只要有魔法方法__iter__的就是可迭代对象  list和tuple和dict都是可迭代对象 迭代器 只要有魔法方法__iter__和__next__的就是可迭代对象 生成器 只要含有y ...

  2. Python学习之旅—生成器对象的send方法详解

    前言 在上一篇博客中,笔者带大家一起探讨了生成器与迭代器的本质原理和使用,本次博客将重点聚焦于生成器对象的send方法. 一.send方法详解  我们知道生成器对象本质上是一个迭代器.但是它比迭代器对 ...

  3. 可迭代对象&迭代器&生成器

    在python中,可迭代对象&迭代器&生成器的关系如下图: 即:生成器是一种特殊的迭代器,迭代器是一种特殊的可迭代对象. 可迭代对象 如上图,这里x是一个列表(可迭代对象),其实正如第 ...

  4. 【Python】【容器 | 迭代对象 | 迭代器 | 生成器 | 生成器表达式 | 协程 | 期物 | 任务】

    Python 的 asyncio 类似于 C++ 的 Boost.Asio. 所谓「异步 IO」,就是你发起一个 IO 操作,却不用等它结束,你可以继续做其他事情,当它结束时,你会得到通知. Asyn ...

  5. 深入理解python中可迭代对象,迭代器,生成器

    英文原文出处:Iterables vs. Iterators vs. Generators 在python学习中,通常会陷入对以下几个相关概念之间的确切差异的困惑中: a container(容器) ...

  6. Python--可迭代对象,迭代器,生成器

    记得在刚开始学Python的时候,看到可迭代对象(iterable).迭代器(iterator)和生成器(generator)这三个名词时,完全懵逼了,根本就不知道是啥意识.现在以自己的理解来详解下这 ...

  7. 闭包在python中的应用,translate和maketrans方法详解

    python对字符串的处理是比较高效的,方法很多.maketrans和translate两个方法被应用的很多,但是具体怎么用常常想不起来. 让我们先回顾下这两个方法吧: 1.s.translate(t ...

  8. Object对象的浅拷贝与深拷贝方法详解

    /* ===================== 直接看代码 ===================== */ <!DOCTYPE html> <html> <head& ...

  9. Python入门之获取当前所在目录的方法详解

    #本文给大家讲解的是使用python获取当前所在目录的方法以及相关示例,非常的清晰简单,有需要的小伙伴可以参考下 sys.path 模块搜索路径的字符串列表.由环境变量PYTHONPATH初始化得到. ...

随机推荐

  1. 利用Python与selenium自动化模拟登陆12306官网!

    近年来,12306的反爬越来越来严重,从一年前的 获取tk参数后到现在增加了 JS.CSS等加密方式! 目前大部分人利用的登陆方式都是利用selenium ,此文也不例外. 环境:        Wi ...

  2. Postgressql高可用(pgpool+异步流复制)

    文档结构: 由于博主之前是Oracle dba,oracle 高可用一般是rac,以及搭建ADG,一个是基于实例的高可用,一个是基于数据的容灾,甚至也有rac+adg的方式.Postgres有同步和异 ...

  3. (三)分布式数据库tidb-隔离级别详解

    tidb隔离级别详解: 1.TiDB 支持的隔离级别是 Snapshot Isolation(SI),它和 Repeatable Read(RR) 隔离级别基本等价,详细情况如下: ● TiDB 的 ...

  4. 模拟实现JSON.stringiry 的格式化输出

    前言 这是一道笔试题,要求模拟实现JSON.stringiry 的格式化输出,按照层级缩进,输出易读格式,即完成以下方法 JSON.stringify(jsObj, null, 4); // 缩进4个 ...

  5. 基于hash和pushState的网页前端路由实现

    客户端路由 对于客户端(通常为浏览器)来说,路由的映射函数通常是进行一些DOM的显示和隐藏操作.这样,当访问不同的路径的时候,会显示不同的页面组件.客户端路由最常见的有以下两种实现方案:* 基于Has ...

  6. maven打包工程出现错误 Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:2.12.4:test

    今天用maven在命令行打包项目的时候出现错误: Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:2.12. ...

  7. 02-21 决策树ID3算法

    目录 决策树ID3算法 一.决策树ID3算法学习目标 二.决策树引入 三.决策树ID3算法详解 3.1 if-else和决策树 3.2 信息增益 四.决策树ID3算法流程 4.1 输入 4.2 输出 ...

  8. cocos2d-x 系统学习cocos(1)

    简析HelloWorld场景 以前使用cocos2d-x 3.14的时候,HelloWorld并不是一个场景类,而是一个图层类,当时的HelloWorld::createScene()是长这样的 Sc ...

  9. java之ReentrantLock详解

    前言 如果一个代码块被synchronized修饰了,当一个线程获取了相应的锁,并执行该代码块时,其他线程便只能一直等待,等待获取锁的释放,现在有这么一种情况,这个获取锁的线程由于要等待IO或者其他原 ...

  10. Java11月18日

    动手动脑 实验一: 1. 下边的程序运行结果是什么? 2.你如何解释会得到这样的输出? 3.计算机是不会出错的,之所以得到这样的运行结果也是有原因的那么从这些运行结果中,你能总结出Java的哪些语法特 ...