博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python3 迭代器和生成器
阅读量:5740 次
发布时间:2019-06-18

本文共 651 字,大约阅读时间需要 2 分钟。

迭代器

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

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

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

迭代器有两个基本方法:iter()  和next()

字符串、列表、或元组对象都可用于创建迭代器。

迭代器对象可以使用常规for语句进行遍历

也可以使用next()函数

 

生成器

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

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

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

调用一个生成器函数,返回的是一个迭代器对象。

对比有yield和没有的情况

有yield执行结果

 

无yield执行结果

什么情况下需要使用yield?

一个函数f,f返回一个list,这个list是动态计算出来的(不管是数学上的计算还是逻辑上的读取格式化),并且这个list会很大(无论是固定很大还是随着输入参数的增大而增大),这个时候,我们希望每次调用这个函数并使用迭代器进行循环的时候一个一个的得到每个list元素而不是直接得到一个完整的list来节省内存,这个时候yield就很有用。

 

转载于:https://www.cnblogs.com/ghming/p/8453839.html

你可能感兴趣的文章
深入理解自定义Annotation,实现ButterKnif小原理
查看>>
vim的快捷键大全
查看>>
doT js模板入门
查看>>
iOS开发中的零碎知识点笔记 韩俊强的博客
查看>>
排序高级之交换排序_冒泡排序
查看>>
Linux文件编辑命令详细整理
查看>>
C#多线程编程
查看>>
linux整理错误集合
查看>>
Cocos2d-x3.2 Ease加速度
查看>>
力求颜值与干货齐高,出品人深度解读三大专场
查看>>
虚拟化平台cloudstack(2)——安装(上)
查看>>
各种排序(数据结构复习之内部排序算法总结)
查看>>
[EntLib]关于SR.Strings的使用办法[加了下载地址]
查看>>
RHCE学习<2>无人值守安装Linux系统(FTP+TFTP+DHCP+Kickstart+PXE)
查看>>
yafphp框架
查看>>
中小型网站架构分析及优化
查看>>
分布式文件存储的数据库——Mongodb
查看>>
UNIX/Linux C 程序员需要掌握的七种武器
查看>>
[mongodb]数据库备份与还原
查看>>
【Oracle】利用在线重定义的方式改变普通表为分区表
查看>>