迭代器

什么是迭代器
  • 迭代是Python最强大的功能之一,是访问序列中元素的一种方式。
  • 迭代器是一个可以记住遍历的位置的对象。
  • 迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束。迭代器只能往前不会后退。
  • 迭代器有两个基本的方法:iter() 和 next()。
可迭代对象
  • 字符串、列表、元组对象等都是可迭代对象
  • 字符串、列表、元组对象等都可以创建迭代器

也就是说:

字符串、列表、元组对象等暂时不是迭代器,暂时不能被迭代。但是,它们成为迭代器之后就可以被迭代了,如for循环。

利用可迭代对象Iterable创建迭代器Iterator
l=[1,2,3,4]     #l:可迭代对象
i=iter(l) #i:迭代器
print(next(i)) #输出1
print(next(i)) #输出2
print(i.__next__()) #输出3

解释:

  • iter()函数可以将可迭代对象创建为迭代器
  • 利用next函数可以得到下一个元素值
  • 迭代器能够记住遍历的位置,所以可以依次调用next()
  • 可迭代对象:Iterable
  • 迭代器:Iterator
  • 可迭代对象不能被迭代,不能调用next()。成为迭代器之后才可以。

注意:

遍历完毕后,若再次调用next()函数,则会抛出异常:StopIteration,处理此异常即可。

处理StopIteration异常
try:
l=[1,2]
i=iter(l)
print(next(i)) #输出1
print(next(i)) #输出2
print(next(i)) #抛出异常
except StopIteration as stopIteration:
print("遍历完成")
刨析for循环

for循环实现了序列的遍历,那它怎么实现的呢?

for循环做的三件事:

  1. 创建迭代器
  2. 调用next方法
  3. 处理StopIteration异常

模拟for循环:

a=[100,200,300,400,500]
j=None
i=iter(a) #1.创建迭代器
while(True):
try:
j=next(i) #2.调用next方法
except StopIteration as stopIteration: #3.处理StopIteration异常
break
print(j)

结果:

100
200
300
400
500

生成器

什么是生成器?
  • 生成器是一种特殊的迭代器。
  • 普通的迭代器将所有数据存放在内存中,极其占用内存空间。
  • 生成器不将数据存入内存,而是通过计算得到数据
生成式生成器
a=(x*x for x in range(4))
print(next(a)) #输出0
print("---------------------")
for i in a: #输出1、4、9
print(i)

解释:

  • 生成式生成器的语法与列表生成式相似,但用小括号( )包裹。列表生成式用[ ]包裹。
  • 数据不会存放在内存中,每一个调用next函数,就会计算一次数据。
  • 使用生成器的好处是:节约内存空间。
函数生成器
  • 函数生成器使用关键字yield来产生数据。
  • 通过next()来得到yield产生的数据
def get():
yield 1
yield 2
g=get()
print(next(g)) #输出1
print(next(g)) #输出2

解释:

  • 依次产生1和2,第三次调用next()则报错
  • 运行yield语句后,python立即设置断点,停止运行此函数,等待下一次调用next()
  • 每次运行,将从上一次的断点处(即上一个yield后)开始运行。
函数生成器-send
  • 通过send函数得到下一个值
  • send函数还可以传入一个值,这个值将被yield接收到
def func():
count1 = yield 1
print("count1=" , count1)
count2 = yield 2
print("count2=" , count2)
yield 3
g = func()
print(g.send(None))
print(g.send(2))

结果:

1
count1= 2
2

解释:

  • count1 = yield 1是赋值语句,先执行等号右边。
  • 运行yield语句后,暂停运行此函数,所以第一次并没有接收值。所以第一次通过send得到值需要用send(None)。
  • 此处的知识可以运用到协程上。

应用-斐波那契序列

可以得到无限多个斐波那契序列中的元素:

def fib():
a=1
b=1
yield a
yield b
while(True):
yield a+b
temp=a+b
a=b
b=temp
f = fib()
for i in range(10):
print(next(f),end=" ")

结果:

1 1 2 3 5 8 13 21 34 55

08-Python迭代器与生成器的更多相关文章

  1. Python 迭代器和生成器(转)

    Python 迭代器和生成器 在Python中,很多对象都是可以通过for语句来直接遍历的,例如list.string.dict等等,这些对象都可以被称为可迭代对象.至于说哪些对象是可以被迭代访问的, ...

  2. 一文搞懂Python迭代器和生成器

    很多童鞋搞不懂python迭代器和生成器到底是什么?它们之间又有什么样的关系? 这篇文章就是要用最简单的方式让你理解Python迭代器和生成器! 1.迭代器和迭代过程 维基百科解释道: 在Python ...

  3. Python - 迭代器与生成器 - 第十三天

    Python 迭代器与生成器 迭代器 迭代是Python最强大的功能之一,是访问集合元素的一种方式. 迭代器是一个可以记住遍历的位置的对象. 迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问 ...

  4. 怎么理解Python迭代器与生成器?

    怎么理解Python迭代器与生成器?在Python中,使用for ... in ... 可以对list.tuple.set和dict数据类型进行迭代,可以把所有数据都过滤出来.如下:         ...

  5. Python迭代器,生成器--精华中的精华

    1. 迭代器 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退.另外,迭代器的一大 ...

  6. python迭代器与生成器详解

    迭代器与生成器 迭代器(iterator)与生成器(generator)是 Python 中比较常用又很容易混淆的两个概念,今天就把它们梳理一遍,并举一些常用的例子. for 语句与可迭代对象(ite ...

  7. Python—迭代器与生成器

    迭代器与生成器 生成器(generator) 先来了解一下列表生成器: list = [i*2 for i in range(10)] print(list)>>>>[0, 2 ...

  8. python -迭代器与生成器 以及 iterable(可迭代对象)、yield语句

    我刚开始学习编程没多久,对于很多知识还完全不知道,而有些知道的也是一知半解,我想把学习到的知识记录下来,一是弥补记忆力差的毛病,二也是为了待以后知识能进一步理解透彻时再回来做一个补充. 参考链接: 完 ...

  9. python迭代器,生成器

    1. 迭代器 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退.另外,迭代器的一大 ...

  10. Python迭代器和生成器你学会了吗?

    在了解什么是迭代器和生成器之前,我们先来了解一下容器的概念.对于一切皆对象来说,容器就是对象的集合.例如列表.元祖.字典等等都是容器.对于容器,你可以很直观地想象成多个元素在一起的单元:而不同容器的区 ...

随机推荐

  1. 数据改变后更新UI(SetProperty/RaiseCanExecuteChanged)

    View代码 1 <StackPanel> 2 <TextBlock Text="方法一"></TextBlock> 3 <TextBox ...

  2. R_回归模型实例一

    工作和生活中存在大量的具有相关性的事件,当找到不同变量之间的关系,我们就会用到回归分析.回归分析(Regression Analysis):是用来确定2个或2个以上变量间关系的一种统计分析方法. 在回 ...

  3. 记录freeswitch的一个2833问题

    概述 freeswitch是一款简单好用的VOIP开源软交换平台. 运营商内部新老系统混用,互联互通的问题较多,其中以DTMF码的问题最多,花样也多. 环境 CentOS 7.9 freeswitch ...

  4. flask注册功能

    一个项目的简单结构划分 首先创建一个新项目 可以正常运行与访问 创建配置文件并添加配置. 将这里拆分到不同的文件中,让启动文件更加简洁. 创建一个apps包,导入配置模块,导入Flask,定义创建ap ...

  5. Oracle批量插入和更新

    一.驱动.使用Oracle.ManagedDataAccess.Client 二.原理.利用OracleCommand的ArrayBindCount属性设置批量大小. 三.实现 函数使用的实体是efc ...

  6. spring boot 在windows下的 批文件部署

    目录结构如下: install.bat @echo off SET JAVA_HOME="C:\Program Files\Java\jdk1.8.0_211\bin" copy ...

  7. web开发遇到的坑之360浏览器缓存问题

    再使用360浏览器,浏览我自己开发的一个配置的web管理后台时,发现,使用ctrl+F5都不能刷新表格的数据,还有,我添加字段时,明明是添加成功的,用sql再数据库查都能查出来.但表格里就是不显示.我 ...

  8. CSS操作——列表属性

    CSS中提供了一些列表属性可以用来: ​ (1).设置不同的列表项标记为有序列表 ​ (2).设置不同的列表项标记为无序列表 ​ (3).设置列表项标记为图像 list-style-type(系统提供 ...

  9. HTML——input之密码框

    在 HTML 中,把 <input> 标签的 type 属性设置为 password 可以表示密码框.具体语法格式如下: <input type="password&quo ...

  10. go 通过指针修改结构体小写字段的值

    package main import ( "fmt" "unsafe" ) type W struct { b int32 c int64 } func ma ...