python迭代器和生成器

一、迭代器

1、什么是迭代器

说迭代器之前有个相关的名词需要介绍: 可迭代对象:只要定义了iter()方法,我们就说该对象是可迭代对象,并且可迭代对象能提供迭代器。

在Python中,for循环可以用于Python中的任何类型,包括列表、元祖等等,实际上,for循环可用于任何“可迭代对象”,这其实就是迭代器。

迭代器是一个实现了迭代器协议的对象,Python中的迭代器协议就是有next方法的对象会前进到下一结果,而到一系列结果的末尾,则会引发StopIteration。任何这类的对象在Python中都可以用for循环或其他遍历工具迭代,迭代工具内部会在每次迭代时调用next方法,并且捕捉StopIteration异常来确定何时离开。

2、为什么要用迭代器

使用迭代器一个显而易见的好处就是:每次只从对象中读取一条数据,不会造成内存的过大开销。

比如要逐行读取一个文件的内容,利用readlines()方法,我们可以这么写:

for line in open("test.txt").readlines():

print line

这样虽然可以工作,但不是最好的方法。因为他实际上是把文件一次加载到内存中,然后逐行打印。当文件很大时,这个方法的内存开销就很大了。

利用file的迭代器,我们可以这样写:

for line in open("test.txt"): #use file iterators

print line

这是最简单也是运行速度最快的写法,他并没显式的读取文件,而是利用迭代器每次读取下一行。

3、如何使用迭代器

使用内建的工厂函数iter(iterable)可以获取迭代器对象(对象包含iter方法即可迭代,iter方法返回一个迭代器):

>>> lst = range(5)

>>> it = iter(lst)

>>> it

使用next()方法访问下一个元素

>>> it.next()

0

>>> it.next()

1

>>> it.next()

2

python处理迭代器越界是抛出StopIteration异常

>>> it.next()

3

>>> it.next

>>> it.next()

4

>>> it.next()

Traceback (most recent call last):

File "", line 1, in

StopIteration

了解了StopIteration,可以使用迭代器进行遍历了:

lst = range(5)

it = iter(lst)

try:

while True:

val = it.next()

print val

except StopIteration:

pass

for语法糖:

>>> lst = range(5)

>>> for i in lst:

... print i

...

0

1

2

3

4

二、生成器

1、什么是生成器

生成器函数在Python中与迭代器协议的概念联系在一起。简而言之,包含yield语句的函数会被特地编译成生成器。当函数被调用时,他们返回一个生成器对象,这个对象支持迭代器接口。函数也许会有个return语句,但它的作用是用来yield产生值的。

2、为什么要使用生成器

Python使用生成器对延迟操作提供了支持。所谓的延迟操作,是指在需要的时候才产生结果,而不是立即产生结果。所以生成器也有了如下的好处: - 1、节省资源消耗,和声明序列不同的是生成器在不使用的时候几乎不占内存,也没有声明计算过程! - 2、使用的时候,生成器是随用随生成,用完即刻释放,非常高效! - 3、可在单线程下实现并发运算处理效果。

3、如何使用生成器

使用斐波那契数列的例子来说明一下:

def fab(max):

n, a, b = 0, 0, 1

while n < max:

yield b

a, b = b, a + b

n = n+ 1

#执行

for n in fab(5):

print n

1

1

2

3

5

该函数通过yield关键字来返回结果,每一次迭代就停止于yield语句处,一直到下一次迭代。

生成器也是一种迭代器,简单地讲,yield 的作用就是把一个函数变成一个 generator,带有 yield 的函数不再是一个普通函数,Python 解释器会将其视为一个 generator,调用 fab(5) 不会执行 fab 函数,而是返回一个 iterable 对象!在 for 循环执行时,每次循环都会执行 fab 函数内部的代码,执行到 yield b 时,fab 函数就返回一个迭代值,下次迭代时,代码从 yield b 的下一条语句继续执行,而函数的本地变量看起来和上次中断执行前是完全一样的,于是函数继续执行,直到再次遇到 yield。看起来就好像一个函数在正常执行的过程中被 yield 中断了数次,每次中断都会通过 yield 返回当前的迭代值。

也可以手动调用 fab(5) 的 next() 方法(因为 fab(5) 是一个 generator 对象,该对象具有 next() 方法),这样我们就可以更清楚地看到 fab 的执行流程:

>>> f = fab(3)

>>> f.next()

1

>>> f.next()

1

>>> f.next()

2

>>> f.next()

Traceback (most recent call last):

File "", line 1, in

StopIteration

4、return的作用

在一个生成器中,如果没有return,则默认执行到函数完毕;如果遇到return,如果在执行过程中 return,则直接抛出 StopIteration 终止迭代。例如:

def read_file(fpath):

BLOCK_SIZE = 1024

with open(fpath, 'rb') as f:

while True:

block = f.read(BLOCK_SIZE)

if block:

yield block

else:

return

如果直接对文件对象调用 read() 方法,会导致不可预测的内存占用。好的方法是利用固定长度的缓冲区来不断读取文件内容。通过 yield,我们不再需要编写读文件的迭代类,就可以轻松实现文件读取。

python迭代器与生成器实际用途_python迭代器和生成器相关推荐

  1. python迭代器和生成器的作用_python迭代器与生成器的详细介绍

    一.什么玩意是迭代器? 先说说什么是迭代吧,迭代就是一件事情重复很多次,比如说for循环. for循环可以对一切有iter方法的对象进行迭代,那么什么是iter方法呢? 一个对象是否可迭代,全都取决于 ...

  2. python迭代器两个基本方法_python迭代器如何实现

    迭代是Python最强大的功能之一,是访问集合元素的一种方式.迭代器是一个可以记住遍历的位置的对象.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退. 迭代器有 ...

  3. python迭代器和for循环区别_python迭代器和for循环区别,

    详细内容 迭代器(iterator):迭代器对象必须同时实现__iter__和__next__方法才是迭代器.对于迭代器来说,__iter__ 返回的是它自身 self,__next__ 则是返回迭代 ...

  4. python迭代器和for循环区别_python迭代器和for循环区别

    迭代器(iterator):迭代器对象必须同时实现__iter__和__next__方法才是迭代器.对于迭代器来说,__iter__ 返回的是它自身 self,__next__ 则是返回迭代器中的下一 ...

  5. python中debug有什么用途_Python debug 总结

    pdb import pdb; pdb.set_trace() (Pdb) 在最近刚发布的 Python 3.7 中,引入了 PPE 553 新特性 beakpoint ( Python 3.7 的新 ...

  6. python库的作用与用途_Python 中 absl 库的用途

    absl 库全称是 Abseil Python Common Libraries.它原本是个C++库,后来被迁移到了Python上. 它是创建Python应用的代码集合.这些代码从谷歌自己的Pytho ...

  7. python迭代器什么时候用_python迭代器与生成器用途是什么

    python迭代器的用途:用next函数获取下一个元素,只能向前取值,不会后退.python生成器的用途:动态提供数据,调用return生成一个StopIteration异常,通知next(it)函数 ...

  8. python的迭代器无法输出值_python迭代器和生成器

    人生还早,谁能笑到最后呢,坚持吧! 1.迭代器协议 由于生成器自动实现了迭代器协议,我们有必要了解迭代器协议是什么,才能更好的理解生成器. 1)迭代器协议:对象要提供__next()__方法,它要么返 ...

  9. python生成器迭代_python中的生成器和迭代器

    前言: 我们来了解一下什么是python中生成器.了解一下python生成器是什么,以及生成器在python编程之中能起到什么样的作用. 定义: 生成器和迭代器 通过列表生成式,我们可以直接创建一个列 ...

最新文章

  1. android 通知折叠点击,如何折叠Android通知?
  2. CSS3 background-size 属性值:cover
  3. Coding:取若干个1到n的整数可求和等于整数m,求出所有组合的个数
  4. c++ reference counting引用计数原理
  5. java 8 新功能详解_Java 8的8个新功能
  6. cuSPARSE库:(八)cusparseGetStream()
  7. 小菜鸟装VM之后装linux
  8. 基于vue2.0与追书神器api的小说阅读webapp
  9. dinic算法 java_网络流问题(Dinic算法JAVA实现)
  10. 《BJBR虚拟仿真解决方案(描述精选)》(Yanlz+SteamVR+5G+AI+VR+AR+MR+HR+BR+CR+DR+ER+FR+GR+人工智能+人机交互+立钻哥哥+==)
  11. 计算机网络教程第五版|微课版 - 第一章 概述 - 习题
  12. 在线CHM阅读器(2)——文件提取及关键文件解析
  13. font setup -- dejavu 安装字体
  14. 路由控制——路由策略与策略路由
  15. linux中常用的截图录屏软件
  16. EcShop开发手册
  17. classes是什么意思怎么读_英语单词class怎么读,class的音标是什么,class是什么意思 - 音标网...
  18. Synergy在Linux与Win10上的下载和安装
  19. 视频教程-Cocos2d-x 游戏开发详解-Cocos
  20. 电力电子技术笔记(4)——典型全控型器件

热门文章

  1. 被逼无奈的树莓派传输文件
  2. 成就感........
  3. 精读《关键对话》:沉默与对抗之外的第三种选择
  4. API接口名称(item_search - 京东按关键字搜索商品)[item_search,item_get,item_search_shop等]
  5. WAP2.0移动互联(转)
  6. 雪狼湖-记忆中最后一个POP音乐
  7. 搜寻吉祥数,在给定的范围内,例如1~99999,找出吉祥数字,满足的条件为:全部数字必须由6或者8构成,如66666,66668,668,…
  8. IntelliJ IDEA 中 Ctrl+Alt+T 快捷键失效、无法弹出surround with、与qq热键冲突-解决办法
  9. Mac上Pycharm激活
  10. AC620FPGA学习笔记——BCD数码管