Python小白学习之路(二十一)—【迭代器】
迭代器
1.迭代器协议
对象必须提供一个 next 方法,执行该方法要么返回迭代中的下一项,要么就引起一个Stoplteration异常,以终止迭代(只能往后走不能往前退)
2.可迭代对象
实现了迭代器协议的对象(如何实现:对象内部定义一个_iter_()方法)
协议是一种约定,可迭代对象实现了迭代器协议,python的内部工具(如 for循环,sum,min,max函数等)使用迭代器协议访问对象
3.关于for循环机制
for循环的本质:循环所有对象,全都是使用迭代器协议
思考:for 循环的本质是遵循迭代器协议去访问对象,那么for循环的对象肯定都是迭代器。那么既然这样,for循环可以遍历(字符串、列表、元祖、字典、集合、
文件对象),那么这些类型的数据肯定都是可迭代对象。但是我们发现,定义了一个字符串 S = ‘xhg’,却发现S.next()方法,违背了迭代器协议。所以不是
迭代对象。
从不同角度分析问题,得出了不同的结论。要想了解具体怎么回事,需要知道for循环内部做了些什么事情
结论:(字符串、列表、元祖、字典、集合、文件对象)这些都不是可迭代对象,只不过在for循环时,
调用了他们内部的 _iter_() 方法,把他们变成了可迭代对象,然后for循环调用可迭代对象的 _next_()
方法去取值,而且for循环会捕捉Stoplteration异常,以终止迭代
f = [1, 2, 3, 4, 5]
for i in f:
print(i)
#分析
第一步:iter_f = f.__iter__() #调用了他们内部的 _iter_() 方法,把他们变成了可迭代对象,遵循可迭代协议
第二步:iter_f.__next__() #调用可迭代对象 iter_f 的 __next__() 方法进行取值
#for循环内部等同于做了以下代码的作用: f = [1, 2, 3, 4, 5]
iter_f = f.__iter__()
print(iter_f)
print(iter_f.__next__())
print(iter_f.__next__())
print(iter_f.__next__())
print(iter_f.__next__())
print(iter_f.__next__())
iter_f.__next__() 等同于 next(iter_f)
4.实现列表取值的两种方法
方法一:索引 f = [1, 2, 3, 4, 5]
print(f[2])
方法二:利用迭代器思想 iter_f = f.__iter__()
print(iter_f.__next__())
print(iter_f.__next__())
5.遍历列表内部全部值的两种方法
方法一:利用 for 循环(基于迭代器协议)
f = [1, 2, 3, 4, 5]
for i in f:
print(i)
方法二:利用 while 循环 f = [1, 2, 3 ,4, 5]
index = 0
while index < len(f):
print(f[index])
index += 1
思考:并非所有类型的数据遍历都可以用while循环。序列类型字符串、列表、元祖都有下标
使用while循环,利用下标遍历,是可以的。但是对于非序列类型数据,如字典、集合、文件对象
的遍历,while 循环无法实现遍历。但是利用 for 循环可以。
因为for 循环就是基于迭代器协议提供了一个统一的可以遍历所有对象的方法。即在遍历前先调用对象的__iter__()方法,
将对象转换为一个迭代器,然后使用迭代器协议就可以实现循环访问。所以 for 循环较为强大。
举例:
#字典的循环:
dic = {'key1':1, 'key2':2}
for i in dic:
print(i) #执行结果
key1
key2 #for 循环作用:
dic = {'key1':1, 'key2':2}
iter_dic = dic.__iter__()
print(iter_dic.__next__())
print(iter_dic.__next__()) #注意:对于字典,默认遍历的是key值
#文件的循环:
f = open('日志文件', 'r+')
for i in f:
print(i,end='')
#执行结果
1111
2222
3333
4444
#注意:for循环每次遍历的是文件的一行内容 #for 循环作用:
f = open('日志文件', 'r+')
iter_f = f.__iter__()
print(iter_f.__next__(), end='')
print(iter_f.__next__(), end='')
print(iter_f.__next__(), end='')
print(iter_f.__next__(), end='')
写在后面:
最近好像有点烦躁
心情也不是很好 阶段性心情差
想打人!!!!
希望睡一觉起来会好一些吧
Python小白学习之路(二十一)—【迭代器】的更多相关文章
- Python小白学习之路(十一)—【局部变量和全局变量】【关键字global】【关键字nonlocal】
写在前面: 几乎有一周没有更新学习笔记了吧 上周一周身体都不怎么舒服 然后还得写开题报告 然后还得看文献 天天就是写写写写写写~~~~~~改改改改改改~~~~~~~~~ 今天又开始学习了 希望之前的没 ...
- Python小白学习之路(二)—【Pycharm安装与配置】【创建项目】【运算符】【数据类型】
写在前面: 第二天的学习,感觉比昨天学习相对轻松一些,但是对于我这个编程语言功底很弱的人来说,还是稍稍微有些.....哈尔滨的天气一天天冷了下来,还飘着小雨,不过还是挺有意境的.充实而又忙碌的生活,让 ...
- Python小白学习之路(二十二)—【生成器】
一.什么是生成器? 生成器可以理解成是一种数据类型,特殊地是生成器可以自动实现迭代器协议其他的数据类型需要调用自己内置的__iter__方法所以换种说法,生成器就是可迭代对象 !回忆:很重要的迭代器协 ...
- Python小白学习之路(二十)—【打开文件的模式二】【文件的其他操作】
打开文件的模式(二) 对于非文本文件,我们只能使用b模式,"b"表示以字节的方式操作(而所有文件也都是以字节的形式存储的,使用这种模式无需考虑文本文件的字符编码.图片文件的jgp格 ...
- Python小白学习之路(二十六)—【if __name__ =='__main__':】【用状态标识操作】
规则一: 一个python文件中,只写一些可以运行的功能测试代码写在这句代码下面 if __name__ =='__main__': 在讲这边的时候,我不是很懂参考了一篇博客,地址如下:http:// ...
- Python小白学习之路(二十四)—【装饰器】
装饰器 一.装饰器的本质 装饰器的本质就是函数,功能就是为其他函数添加附加功能. 利用装饰器给其他函数添加附加功能时的原则: 1.不能修改被修饰函数的源代码 2.不能修改被修饰函数的调用 ...
- Python小白学习之路(二十三)—【生成器补充】
生成器的一些补充 接着下鸡蛋和吃包子! 补充一:生成器只能遍历一次 (总是把生成器比喻成母鸡下鸡蛋,需要一个下一个,首先是下出来的鸡蛋不能塞回母鸡肚子里,其次是一个母鸡一生只能下一定数量的鸡蛋,下完了 ...
- Python小白学习之路(十七)—【内置函数二】
序列操作类函数 all() 功能:判断可迭代对象的每个元素是否都为True值注意:If the iterable is empty, return True.(举例3) 回顾:None '' ...
- Python小白学习之路(二十五)—【装饰器的应用】
通过一个任务来加深对装饰器的理解和应用 回顾:装饰器的框架 def timmer(func): def wrapper(): func() return wrapper 任务:给以下正在运行的程序加一 ...
随机推荐
- xxnet 360浏览器设置
开xxnet全局pac只能代理. 然后选择360浏览器里面使用ie代理设置就行
- 实现KbmMw web server 支持https
在以前的文章里面介绍过kbmmw 做web server. 前几天红鱼儿非要我给他做一个支持https 的web server. 其实kbmmw 支持https 有好几种方法: 1. 使用isapi ...
- spring mvc 用cookie和拦截器实现自动登录(/免登录)
Cookie/Session机制详解:http://blog.csdn.net/fangaoxin/article/details/6952954 SpringMVC记住密码功能:http://blo ...
- 2018.10.18 bzoj1185: [HNOI2007]最小矩形覆盖(旋转卡壳)
传送门 不难看出最后的矩形一定有一条边与凸包某条边重合. 因此先求出凸包,然后旋转卡壳求出当前最小矩形面积更新答案. 代码: #include<bits/stdc++.h> #define ...
- 2018.10.02 NOIP模拟 矩阵分组(二分答案)
传送门 考场上并不会写二分的check函数,下来看了看题解发现真是妙极. 不难想到每次直接从四个角各按阶梯状拓展出合法区域A,再检验B是否合法就行了.(然而考场上写的弃疗了) 于是题解用了一些小技巧优 ...
- 2018.09.28 bzoj3743: [Coci2015]Kamp(树形dp)
传送门 这是一道很有意思的题. 我们把所有的关键点都提出来,当成一棵有边权的虚树. 然后发现虚树上除最后不回到虚根的那条路径外外每条边都会被走两遍. 显然要让答案最优,不走的路径应该在虚树的直径上,于 ...
- 2018.07.07 BZOJ2212: Poi2011Tree Rotations(线段树合并)
2212: [Poi2011]Tree Rotations Time Limit: 20 Sec Memory Limit: 259 MB Description Byteasar the garde ...
- 第三章 形容词(Les adjectifs)
★形容词的性(Le genre de l'adjectif ) ()一般规则是在阳性形容词后加-e: français ➞francaise法国的 content ➞c ...
- Linux教程:基础+中级+运维高级
视频内容40G:Linux基础视频.Linux中级视频.Linux运维高级视频+赠送 职业素质视频 +查用服务器安卓文档 目录 Linux基础教程81节 常用命令.文件管理命令详解.bash脚本编程. ...
- ViewFlipper实现自动播放的图片库
作者实现的基础上,加上了文字的变换 public class MainActivity extends Activity { private ViewFlipper viewFlipper; priv ...