python基础之迭代器协议和生成器(二)
一、什么是迭代器:
迭代是Python最强大的功能之一,是访问集合元素的一种方式。
迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束。
迭代器是一个可以记住遍历的位置的对象。
迭代器的特点:只能往前不会后退。
迭代器有两个基本的方法:__iter__ 和 __next__或者iter()和next()。
1、iter方法:返回迭代器对象本身
2、next方法:返回迭代器的下一个元素
可迭代的:只要对象本身有__iter__方法,那它就是可迭代的。
字符串,列表或元组对象都可用于创建迭代器:
list = [1,2,3,4] #list列表
r = iter(list)用iter方法将list转成迭代器赋值给r
print(next(r)) #用next方法使用迭代器r,并输出结果
print(next(r)) #因为迭代器是一次性的,so,要想看下面的内容,\
# 还得用next方法使用迭代器r,并输出结果
----------------以下是输出结果--------------------
>>> print(next(r))
1
>>> print(next(r))
2
>>> print(next(r))
3
>>> print(next(r))
4
>>>
二、迭代器的优点:
1、迭代器提供了一种不依赖于索引的取值方式,这样就可以遍历那些没有索引的可迭代对象了(字典,集合,文件);
2、迭代器与列表比较,迭代器是惰性计算的,更节省内存。
三、迭代器的缺点:
1、无法获取迭代器的长度,使用不如列表索引取值灵活;
2、一次性的,只能往后取值,不能倒着取值。就像象棋里卒一样不能倒着走。
用代码展示如下:
下面来用代码展示一下吧:
>>> d={"a":1,"b":2,"c":3} #定义了一个字典
>>> r = iter(d) #用iter方法将字典转成了一个迭代器并赋值给r
>>> while True: #定义了一个死循环
... print(next(r)) #用next调用迭代器r
...
a #一直循环next的话,超出了元素的个数的时候就会报错
b
c
Traceback (most recent call last):
File "<stdin>", line 2, in <module>
StopIteration #报错的内容
正确的代码如下:
while循环
d = {"a":1,"b":2,"c":3}
r = iter(d)
while True: #加上try之后,它会自己判断,超出后会自动break
try:
print(next(r))
except StopIteration:
break
----------输出内容-------------
a
b
c
d = {"a":1,"b":2,"c":3}
for i in d: #for循环,遍历字典的中的每一个元素
print(i)
----------输出-----------
a
b
c
总结:不难看出for的作用是遍历迭代器——对一个迭代器(实现了 __next__)或者可迭代对象(实现了 __iter__)。
查看可迭代对象与迭代器对象:
#查看是否是可迭代对象(True为是,False为否)
print(isinstance(s,Iterable)) #------>True
print(isinstance(l,Iterable)) #------>True
print(isinstance(t,Iterable)) #------>True
print(isinstance(d,Iterable)) #------>True
print(isinstance(set1,Iterable)) #------>True
print(isinstance(f,Iterable)) #------>True #查看是否是迭代器
f.__next__()
print(isinstance(s,Iterator)) #--------->False #字符串
print(isinstance(l,Iterator)) #--------->False #列表
print(isinstance(t,Iterator)) #--------->False #元组
print(isinstance(d,Iterator)) #--------->False #字典
print(isinstance(set1,Iterator)) #--------->False #集合
print(isinstance(f,Iterator)) #--------->True #文件
四、生成器
定义:
在 Python 中,使用了 yield 的函数被称为生成器(generator)。
跟普通函数不同的是,生成器是一个返回迭代器的函数,只能用于迭代操作,更简单点理解生成器就是一个迭代器。
在调用生成器运行的过程中,每次遇到 yield 时函数会暂停并保存当前所有的运行信息,返回yield的值。并在下一次执行 next()方法时从当前位置继续运行。
下面用实例使用 yield 实现斐波那契数列:
def fibonacci(n): #生成器函数-斐波那契数列
a,b,counter = 0,1,0
while True:
if (counter > n):
return
yield a
a,b=b,a+b
counter += 1
f = fibonacci(10) # f 是一个迭代器,由生成器返回生成 while True:
try:
print(next(f),end=" ")
except StopIteration:
break
生成器与return有何区别?
return只能返回一次函数就彻底结束了,而yield能返回多次值。
函数在暂停以及继续下一次运行时的状态是由
yield
保存
return作用:
在一个生成器中,如果没有return,则默认执行到函数完毕;
如果遇到return,在执行过程中 return,则直接抛出 StopIteration 终止迭代。
python基础之迭代器协议和生成器(二)的更多相关文章
- (转)python基础之迭代器协议和生成器(一)
一 递归和迭代 二 什么是迭代器协议 1.迭代器协议是指:对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个StopIteration异常,以终止迭代 (只能往后走不能往前 ...
- python基础之迭代器协议和生成器
迭代器和生成器补充:http://www.cnblogs.com/luchuangao/p/6847081.html 一 递归和迭代 略 二 什么是迭代器协议 1.迭代器协议是指:对象必须提供一个ne ...
- python基础之迭代器协议和生成器(一)
一 递归和迭代 二 什么是迭代器协议 1.迭代器协议是指:对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个StopIteration异常,以终止迭代 (只能往后走不能往前 ...
- python基础之 迭代器回顾,生成器,推导式
1.迭代器回顾 可迭代对象:Iterable 可以直接作用于for循环的对象统称为可迭代对象:Iterable.因为可迭代对象里面存在可迭代协议,所以才会被迭代 可迭代对象包括: 列表(list) 元 ...
- python 迭代器协议和生成器
一.什么是迭代器协议 1.迭代器协议是指:对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个stoplteration异常,以终止迭代(只能往后走,不能往前退) 2.可迭代 ...
- Python基础之迭代器和生成器
阅读目录 楔子 python中的for循环 可迭代协议 迭代器协议 为什么要有for循环 初识生成器 生成器函数 列表推导式和生成器表达式 本章小结 生成器相关的面试题 返回顶部 楔子 假如我现在有一 ...
- python学习------迭代器协议和生成器
一.递归和迭代 递归:自己调用自己 举例解释:问路 A问B康明网络科技怎么走,B说我不是很清楚,我帮你问问C,C说我也不知道.我问问D,D说 就在兴隆.之后D返回结果给C,C返回结果给B,B返回结 ...
- Python之路迭代器协议、for循环机制、三元运算、列表解析式、生成器
Python之路迭代器协议.for循环机制.三元运算.列表解析式.生成器 一.迭代器协议 a迭代的含义 迭代器即迭代的工具,那什么是迭代呢? #迭代是一个重复的过程,每次重复即一次迭代,并且每次迭代的 ...
- python基础8 -----迭代器和生成器
迭代器和生成器 一.迭代器 1.迭代器协议指的是对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个StopIteration异常,以终止迭代 (只能往后走不能往前退) 2. ...
随机推荐
- 【人员招聘】岗位职责和技能要求——By Me
- FPGA电源设计
LDO(低压差线性稳压器),FPGA需要3.3V.2.5V和1.2V,可选用凌力尔特LINEAR:LT1083/84/85,低压差正压可调稳压器. 应用电路如图所示: 输入端加10UF电解电容,输出端 ...
- c++ 库 boost安装
http://blog.chinaunix.net/uid-12226757-id-3427282.html ubuntu apt-get install libboost-dev 全部: apt-g ...
- 入门拾遗 day2
一.类和对象 对于Python,一切事物都是对象,对象基于类创建 学会查看帮助 type(类型名) 查看对象的类型dir(类型名) 查看类中提供的所有功能help(类型名) 查看类中所有详细的功能he ...
- java基本类型和包装器类
java是一种面向对象语言,java中的类把方法与数据连接在一起,并构成了自包含式的处理单元.但在java中不能定义基本类型(primitive type),为了能将基本类型视为对象来处理,并能连接相 ...
- ORACLE 多表连接与子查询
Oracle表连接 SQL/Oracle使用表连接从多个表中查询数据 语法格式: select 字段列表from table1,table2where table1.column1=table2.co ...
- Java Web架构总结
转载至:http://www.cnblogs.com/wuxl360/p/7489763.html 初始搭建 开始的开始,就是各种框架一搭,然后扔到Tomcat容器中跑就是了,这时候我们的文件,数据库 ...
- 跟着实例学习ZooKeeper的用法: 分布式锁
锁 分布式的锁全局同步, 这意味着任何一个时间点不会有两个客户端都拥有相同的锁. 可重入锁Shared Reentrant Lock 首先我们先看一个全局可重入的锁. Shared意味着锁是全局可见的 ...
- Microsoft.VisualStudio.Web.PageInspector.Loader
未能加载文件或程序集"Microsoft.VisualStudio.Web.PageInspector.Loader, Version=1.0.0.0, Culture=neutral, P ...
- Saltstack sls文件:批量安装服务
一.使用saltstack 批量安装nginx 1.创建salt目录 mkdir /srv/{salt,pillar} 2.再/srv/salt/下创建sls文件 vim nginx_install. ...