一.迭代器

迭代是Python最强大的功能之一,是访问集合元素的一种方式。。

迭代器是一个可以记住遍历的位置的对象。

迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束。迭代器只能往前不会后退。

迭代器有两个基本的方法:iter() 生成迭代器和 next()遍历迭代器元素。

 >>> dil = iter(range(10))  #使用iter方法创建一个迭代器
>>> print(type(dil)) #类型为迭代器
<class 'range_iterator'>
>>> print(dil)
<range_iterator object at 0x7fb9bf466ed0>
>>> l1 = [1,2,3,4,5]
>>> it = iter(l1) #将列表转换为迭代器
>>> print(type(it))
<class 'list_iterator'>
>>> print(it)
<list_iterator object at 0x7fb9bf42e9e8> >>> print(next(it))
>>> print(next(it))
>>> print(next(it))
>>> print(next(it))
>>> print(next(it))
>>> print(next(it)) #如果迭代器元素到最后没有了就会报错
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
StopIteration
>>> for i in it: #此处因为迭代元素已经到了最后,所以没有元素输出
... print(i,end=" ")
... >>> print(next(dil)) #使用next输出迭代器的下一个元素
>>> print(next(dil))
>>> print(next(dil))
>>> print(next(dil))
>>> for i in dil: #而输出dil迭代器的元素会接着输出迭代器的元素,知道最后一个。
... print(i,end=" ")
...
5 6 7 8 9 >>> >>> list = [1,2,3,4,5,6,7,8]
>>> inter1 = list.__iter__() #遵循迭代器协议,生成可以迭代的对象
>>> print(inter1.__next__())
>>> print(inter1.__next__()) #集合中使用迭代器
>>> s1 = {'python','java','net','php'}
>>> iter2 = s1.__iter__()
>>> print(iter2)
<set_iterator object at 0x7fb9bf450ea0>
>>> print(iter2.__next__())
java
>>> print(iter2.__next__())
php
>>> print(iter2.__next__())
net
>>> print(iter2.__next__())
python
>>> print(iter2.__next__()) #字典中使用迭代器
>>> dict1 = {'k1':'v1','k2':'v2'}
>>> iter3 = dict1.__iter__()
>>> print(iter3.__next__()) #字典默认迭代的是key值
k1
>>> print(iter3.__next__())
k2 #文件中使用迭代器
>>> with open('test','r') as f1:
... iter5 = f1.__iter__()
... print(iter5.__next__(),end = ' ')
... print(iter5.__next__(),end = ' ')
... print(iter5.__next__(),end = ' ')
...
2222
4444
6666

二.生成器

在 Python 中,使用了 yield 的函数被称为生成器(generator)。

跟普通函数不同的是,生成器是一个返回迭代器的函数,只能用于迭代操作,更简单点理解生成器就是一个迭代器。

在调用生成器运行的过程中,每次遇到 yield 时函数会暂停并保存当前所有的运行信息,返回yield的值。并在下一次执行 next()方法时从当前位置继续运行。

生成器可以理解为一种数据类型,这种数据类型自动实现了迭代器协议(其他的数据类型需要调用自己内置的__iter__方法),所以生成器就是可迭代对象

生成器分类及在python中的表现形式:(Python有两种不同的方式提供生成器)

    1.生成器函数:常规函数定义,但是,使用yield语句而不是return语句返回结果。yield语句一次返回一个结果,在每个结果中间,挂起函数的状态,以便下次重它离开的地方继续执行

    2.生成器表达式:类似于列表推导,但是,生成器返回按需产生结果的一个对象,而不是一次构建一个结果列表

为何使用生成器之生成器的优点

Python使用生成器对延迟操作提供了支持。所谓延迟操作,是指在需要的时候才产生结果,而不是立即产生结果。这也是生成器的主要好处。

生成器小结:

1.是可迭代对象

2.实现了延迟计算,省内存啊

3.生成器本质和其他的数据类型一样,都是实现了迭代器协议,只不过生成器附加了一个延迟计算省内存的好处

 def ite():
print('hello')
yield 'test1'
print('world')
yield 'test2'
yield 'test3'
yield 'test4' gen = ite() #生成了一个生成器
print(type(gen))
print(gen.__next__())
print(gen.__next__())
print(gen.__next__())
print(gen.__next__()) <class 'generator'>
hello
test1
world
test2
test3
test4

生成器方法:

close():手动关闭生成器,后面的调用会直接返回Stoplteration异常。

 >>> def gen():
... yield 'hello'
... yield 'python'
...
>>> st = gen()
>>> print(st.__next__())
hello
>>> st.close() #关闭生成器后再显示元素就抛出异常
>>> print(st.__next__())
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
StopIteration

send():生成器函数最大的特点是可以接受外部传入的一个变量,并根据变量内容计算结果后返回。

 def consumer(name):
print('begin..')
while True:
baozi = yield name #第一次执行时返回name的值,然后将send的值赋值给yield
print('is you %s' %baozi) #所以此时baozi的值为1 d = consumer('zhang')
print(d.__next__())
print(d.send(1))
print(d.send(2))
print(d.send(3))
print(d.send(5)) begin..
zhang
is you 1
zhang
is you 2
zhang
is you 3
zhang
is you 5
zhang

throw():用来想生成器函数传入一个异常,可以结束系统定义的异常,或者自定义的异常。

throw()后直接抛出异常并结束程序,或者消耗掉一个yield,或者在没有下一个yield的时候直接进行到程序的结尾。

三.闭包

四.装饰器

Python四大神兽(迭代器&生成器&闭包&装饰器)的更多相关文章

  1. Day4- Python基础4 深浅拷贝、三目运算、列表生成式,迭代器&生成器、装饰器

    本节内容: 1.深浅拷贝 2.三目运算 3.迭代器和生成器 4.装饰器 1.深浅拷贝 拷贝意味着对数据重新复制一份,深浅拷贝的含义就是:对于修改复制的数据是否会影响到源数据,拷贝操作对于基本数据结构需 ...

  2. Python学习笔记——基础篇【第四周】——迭代器&生成器、装饰器、递归、算法、正则表达式

    目录 1.迭代器&生成器 2.装饰器 a.基本装饰器 b.多参数装饰器 3.递归 4.算法基础:二分查找.二维数组转换 5.正则表达式 6.常用模块学习 #作业:计算器开发 a.实现加减成熟及 ...

  3. Python 闭包、迭代器、生成器、装饰器

    Python 闭包.迭代器.生成器.装饰器 一.闭包 闭包:闭包就是内层函数对外层函数局部变量的引用. def func(): a = "哈哈" def func2(): prin ...

  4. python的迭代器、生成器、装饰器

    迭代器.生成器.装饰器 在这个实验里我们学习迭代器.生成器.装饰器有关知识. 知识点 迭代器 生成器 生成器表达式 闭包 装饰器 实验步骤 1. 迭代器 Python 迭代器(Iterators)对象 ...

  5. Python全栈开发之4、迭代器、生成器、装饰器

    一.迭代器 1.为何要有迭代器? 对于序列类型:字符串.列表.元组,我们可以使用索引的方式迭代取出其包含的元素.但对于字典.集合.文件等类型是没有索引的,若还想取出其内部包含的元素,则必须找出一种不依 ...

  6. python is、==区别;with;gil;python中tuple和list的区别;Python 中的迭代器、生成器、装饰器

    1. is 比较的是两个实例对象是不是完全相同,它们是不是同一个对象,占用的内存地址是否相同 == 比较的是两个对象的内容是否相等 2. with语句时用于对try except finally 的优 ...

  7. python之路6-迭代器、生成器、装饰器

    1.迭代器&生成器 列表生成式 现在有个需求,列表[1,2,3,4,5,6,7,,8,9],要求把列表里的每个值加1,如何实现? 方法一: list = [1,2,3,4,5,6,7,8,9] ...

  8. Python闭包装饰器笔记

    Python三大器有迭代器,生成器,装饰器,这三个中使用最多,最重要的就是装饰器.本篇将重要从函数嵌套开始讲起,从而引入闭包,装饰器的各种用法等. python中的一切都是一个对象(函数也是) 1.首 ...

  9. Python3基础教程(十六)—— 迭代器、生成器、装饰器

    在这个实验里我们学习迭代器.生成器.装饰器有关知识. 这几个概念是 Python 中不容易理解透彻的概念,务必把所有的实验代码都完整的输入并理解清楚其中每一行的意思. 迭代器 Python 迭代器(I ...

随机推荐

  1. Powershell Deploy Service Fabric Application To Local Cluster

    之前写过一篇用 Powershell 部署 Service Fabric Application 到本地集群的随笔,感觉过程有点复杂,这次将流程简化,只需要将应用程序打包,加上配置文件就可以了.   ...

  2. 167. Two Sum II - Input array is sorted两数之和

    1. 原始题目 给定一个已按照升序排列 的有序数组,找到两个数使得它们相加之和等于目标数. 函数应该返回这两个下标值 index1 和 index2,其中 index1 必须小于 index2. 说明 ...

  3. 读《JavaScript权威指南》笔记(四)--数组、函数

    一.数组 1.数组是值的有序集合.每个值叫做一个元素,而每个元素在数组中有一个位置,以数字表示,称为索引.JavaScript数组是无类型的:数组元素可以是任意类型,并且同一个数组中的不同元素也可能有 ...

  4. 【转】ROWNUM与ORDER BY先后关系

    源地址:http://www.cnblogs.com/accumulater/p/6137385.html

  5. loj #6250. 「CodePlus 2017 11 月赛」找爸爸

    #6250. 「CodePlus 2017 11 月赛」找爸爸 题目描述 小 A 最近一直在找自己的爸爸,用什么办法呢,就是 DNA 比对. 小 A 有一套自己的 DNA 序列比较方法,其最终目标是最 ...

  6. [51nod1237] 最大公约数之和 V3(杜教筛)

    题面 传送门 题解 我好像做过这题-- \[ \begin{align} ans &=\sum_{i=1}^n\sum_{j=1}^n\gcd(i,j)\\ &=\sum_{d=1}^ ...

  7. C# 添加,修改,删除Xml节点

    //添加xml节点    private void AddXml(string image, string title)     {        XmlDocument xmlDoc = new X ...

  8. 背包 DP【洛谷P4158】 [SCOI2009]粉刷匠

    P4158 [SCOI2009]粉刷匠 windy有 N 条木板需要被粉刷. 每条木板被分为 M 个格子. 每个格子要被刷成红色或蓝色. windy每次粉刷,只能选择一条木板上一段连续的格子,然后涂上 ...

  9. kuangbin专题十二 HDU1114 Piggy-Bank (完全背包)

    Piggy-Bank Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total ...

  10. [USACO19FEB]Moorio Kart(DP)

    Luogu5243 题解 即O(N^2)暴力统计出每个森林的路径,从ctgn个集合中各选出一个数,使得长度>=Y的方案数. 用背包统计.具体实现: \(dp[i+j][0]\leftarrow ...