python之路之迭代器与生成器
一 迭代器
那么在研究迭代器之前首先应该要知道什么是迭代。
迭代:是一个重复的过程,并且每次重复都是建立基于上一次的结果而来的,所以在迭代的过程其实是在不断变化的。
迭代器:就是迭代取值的工具。
那么对于这个工具的使用,在python使用迭代的方法就是使用内置的——iter——,换言之就是说能够调用该方法的都叫可迭代的对象。
那么对于迭代器的优缺点:
优点就是:1 提供一种不依赖于索引的取之方式。
2 更加省内存,因迭代器运行时每次只取一个值,
缺点:取值麻烦,只能一个一个取,而且只能向后取,全部的值只能取一次,没办法用len获取长度。
迭代器对象:可迭代的对象执行--iter--方法得到的返回值即使迭代器对象。
迭代器对象一定是可迭代的对象,而可迭代的对象不一定是迭代器对象。
s='hello'
inter_s=s.__iter__()
while True:
try:
print(inter_s.__next__())
except StopIteration:
break
那么一般平时比较常用的列表,字典,元组,file等都是可迭代对象,那么其中有一个比较特殊的就是file,因file本身就是迭代器对象既能调用--itrer也能调用--next--, 调用iter时,结果还是它本身。 迭代器最典型的例子就是for循环: for line in l:那么for循环首先对l做一个调用--iter--的操作,拿到迭代器,然后再通过调用--next--拿到返回值,赋值给line. for循环自动检测stopiteration。在值取尽时,结束for循环。 二 生成器 函数内含有yield关键字,再调用函数就不会执行函数体代码,拿到的返回值就是一个生成器对象。
f=open('a.txt','r',)
f.__next__()
f.__iter__()
def chicken():
print('--------1')
yield
print('=======2')
yield
print('-----3')
yield
obj=chicken()
print(obj)
# print(obj.__next__())
print(obj.__iter__().__next__())#生成器的本质就是迭代器
print(obj.__iter__().__next__())
print(obj.__iter__().__next__())
生成器本质就是迭代器
def rang():
print('===')
n =
while True:
yield n
n+= obj=rang()
# print(obj)
print(obj.__next__())
print(obj.__next__())#第二次执行时会从yield开始,所以yield保持程序运行的状态。
print(obj.__next__())
# for item in obj:
# print(item)
生成一种迭代器,相当于for循环
def rang(start,stop,step):
n=start
while n<stop:
yield n
n+=step obj=rang(,,)
print(obj.__next__())
print(obj.__next__())
# for item in obj:
# print(item) 就相当于
for item in range(,,):
print(item)
总结生成器:
1 给我们提供一种自定义迭代器的方式,可以在函数内用yield关键字,调用函数拿到的结果就是一个生成器,生成器就是迭代器。
2 yield可以象return一样用于返回值,区别是return只能返回一次值,而yield可以返回多次,因程序遇见return就会结束,yield可以保存函数的一个执行状态。
协程函数:
#yield关键字的另外一种使用形式:表达式形式的yield
def eater(name):
print('%s 准备开始吃饭啦' %name)
food_list=[]
while True:
food=yield food_list
print('%s 吃了 %s' % (name,food))
food_list.append(food) g=eater('Feng')
g.send(None) #对于表达式形式的yield,在使用时,第一次必须传None,g.send(None)等同于next(g)
g.send('烤鸡')
g.send('烤鸭')
g.send('猴脑')
g.send('熊掌')
g.close()
g.send('鱼刺')
g.send('鲍鱼')
面向过程编程:
优点:将复杂流程化,进而简化。 缺点:修改一个阶段,可能其他阶段也要修改,所以容错率低,改进麻烦。
python之路之迭代器与生成器的更多相关文章
- 完全理解 Python 迭代对象、迭代器、生成器(转)
完全理解 Python 迭代对象.迭代器.生成器 本文源自RQ作者的一篇博文,原文是Iterables vs. Iterators vs. Generators » nvie.com,俺写的这篇文章是 ...
- 完全理解 Python 迭代对象、迭代器、生成器
完全理解 Python 迭代对象.迭代器.生成器 2017/05/29 · 基础知识 · 9 评论 · 可迭代对象, 生成器, 迭代器 分享到: 原文出处: liuzhijun 本文源自RQ作者 ...
- Python之模块,迭代器与生成器
本节涉及内容: 1. 迭代器和生成器 2. 递归 3. 字符串格式化 4. 模块 内置模块 自定义模块 第三方模块 5. 序列化的模块 json pickle (一). 迭代器和生成器: 迭代器: ...
- python学习笔记四 迭代器,生成器,装饰器(基础篇)
迭代器 __iter__方法返回一个迭代器,它是具有__next__方法的对象.在调用__next__方法时,迭代器会返回它的下一个值,若__next__方法调用迭代器 没有值返回,就会引发一个Sto ...
- 理解Python迭代对象、迭代器、生成器
作者:zhijun liu链接:https://zhuanlan.zhihu.com/p/24376869来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 本文源自RQ作 ...
- python基础篇_005_迭代器和生成器
Python迭代器和生成器 1.迭代器 迭代:可以将某个数据集内的数据“一个挨着一个的取出来” for i in range(1, 10, 2): # in 后面的对象必须是一个可迭代的 print( ...
- 【笔记】Python基础四:迭代器和生成器
一,迭代器协议和for循环工作机制 (一),迭代器协议 1,迭代器协议:对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个stopiteration异常,以终止迭代(只能往 ...
- Python开发——函数【迭代器、生成器、三元表达式、列表解析】
递归和迭代 小明问路篇解释说明 递归:小明——>小红——>小于——>小东:小东——>小于——>小红——>小明 小明向小红问路,因小红不知道,所以向小于问路,因小于不 ...
- [转载]完全理解Python迭代对象、迭代器、生成器
译文地址:liuzhijun 在了解Python的数据结构时,容器(container).可迭代对象(iterable).迭代器(iterator).生成器(generator).列表/集合/字典推导 ...
随机推荐
- JavaScript学习(二)——深入学习js对象的原型与继承
了解对象 什么是对象? …… 这个就不说了 对象的声明的两种方式 var person = new Object(); person.name="linchen"; pers ...
- A+B for Input-Output Practice (VII)
A+B for Input-Output Practice (VII) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 ...
- TypeError: HashUpdate fail
关于crypto的md5加密报错: 代码: var crypto = require('crypto'); var md5 = crypto.createHash('md5'); //crypto模块 ...
- CentOS下设置MySQL的root各种密码 总结
一.更改mysql密码常用的三种方法 大部分情况下,一般用户没有权限更改密码,只有申请了权限或root用户才可以更改密码: 1.方法1:用mysqladmin mysqladmin -u root p ...
- Springboot整合pagehelper分页
一.在pom中添加依赖 <dependency> <groupId>com.github.pagehelper</groupId> <artifactId&g ...
- 【Quartz】Quartz的数据库表
select * from test.QRTZ_TRIGGERS 触发器表 select * from QRTZ_PAUSED_TRIGGER_GRPS 暂停的分组任务表 select * from ...
- LG3372 【【模板】线段树 1】
介绍我的三种算法 1.线段树 既然这题是线段树板子,我还是尊重一下先发这个.跑的时间376ms不是很快,但也还是不错.O(nlogn). #include<iostream> #inclu ...
- LG3804 【模板】后缀自动机
题意 给定一个只包含小写字母的字符串\(S\), 请你求出 \(S\) 的所有出现次数不为 \(1\) 的子串的出现次数乘上该子串长度的最大值. 对于\(100\%\) 的数据,\(|S| \leq ...
- 练习SQL代码
---------PS:但凡有聚合函数(where),必然后Group by,Group by后面跟having ---------面试题 SELECT name,sum(fen) as s from ...
- MySQL的innoDB锁机制以及死锁处理
MySQL的nnoDB锁机制 InnoDB与MyISAM的最大不同有两点:一是支持事务(TRANSACTION):二是采用了行级锁.行级锁与表级锁本来就有许多不同之处,innodb正常的select ...