Python帮助文档中Iteration iterator iterable 的理解
iteration这个单词,是循环,迭代的意思。也就是说,一次又一次地重复做某件事,叫做
iteration。所以很多语言里面,循环的循环变量叫i,就是因为这个iteration。
iteration指的是循环这个动作本身。而,循环可以做很多事情,一种事情就是便利一个容器里面所有的值
那么遍历这件事情那么长江,就做了一个理论上的抽象:如果我是为了遍历什么东西而循环,那么就称之为
我在一个【迭代器】上循环
iterator,迭代器,就是【循环的那个东西】
单词结尾的or, 指......的人,比如writer,作家,painter,画家
iterate,循环,动词,iteration,循环,名词,iterator,循环的东西,就是迭代器
迭代器有三个操作:判断是不是循环完了,取得当前值,和移动到下一个值。就是C++
里面的for(iterator it = c.begin(); it != c.end(); ++it){ *it=......;}
*it是取得当前值,++it是迭代到下一个值(这里就出现了循环的含义了),而it!=c.end()就是
判断循环是否结束。
所有可以循环的东西,其实只需要支持这三个值,就能直接拿来循环了。因此Python做了包装,
认为一个东西是【可循环】的,就是实现了这三种操作的东西
iterable,iter-able,可循环的。
一个【可循环】的东西,就是可以得到一个【iterator】迭代器的东西。
Python通过调用对象身上的__iter__方法获得一个迭代器,而具备__iter__方法的对象,就被
叫做【可迭代的】,iterable
在Python里,任何实现了__next__方法的对象,都可以被当作迭代器
而任何实现了__iter__方法并返回一个迭代器的对象,都可以放在for...in...这里循环
比如for i in range(100):pass, range返回的对象就实现了__iter__,而range(10).__iter__()返回
的对象就实现了__next__。range(10)的返回值被称为iterable,iterable.__iter__()的返回值被称为
iterator,for i in range(10): pass这个过程叫iterate, 这个动作本身作为一个名词讲,就是iteration。
类比一下,
__iter__就是c.begin()
__next__就是*++it
__next__会抛出一个StopIteration异常,类比于it != c.end()这个行为。
抛StopIteration异常的这个行为和判断it == c.end()这个行为是等价的。
实现了一些一样的行为,就成为了一种类型的东西,这种概念,以后会一直遇到。
C++叫class/template,C#/Java叫interface,Rust/nim叫trait,Python里面没有这个概念,
但是文档里面还是会经常用到。
比如callable,任何可以当函数调用的对象,都是callable的,iterable只是类似的概念罢了。
Python帮助文档中Iteration iterator iterable 的理解的更多相关文章
- python统计文档中词频
python统计文档中词频的小程序 python版本2.7 效果如下: 程序如下,测试文件与完整程序在我的github中 #统计空格数与单词数 本函数只返回了空格数 需要的可以自己返回多个值 def ...
- python读入文档中的一行
从文件log_fusion中读入数据 方法1 f = open("log_fusion.txt") # 返回一个文件对象 line = f.readline() # 调用文件的 r ...
- 利用python处理文档中各字段出现的次数并排序
import string path = 'waldnn' with open(path,'r') as text: words = [raw_word.strip(string.punctuatio ...
- 2018-10-04 [日常]用Python读取word文档中的表格并比较
最近想对某些word文档(docx)的表格内容作比较, 于是找了一下相关工具. 参考Automate the Boring Stuff with Python中的word部分, 试用了python-d ...
- 用python从符合一定格式的txt文档中逐行读取数据并按一定规则写入excel(openpyxl支持Excel 2007 .xlsx格式)
前几天接到一个任务,从gerrit上通过ssh命令获取一些commit相关的数据到文本文档中,随后将这些数据存入Excel中.数据格式如下图所示 观察上图可知,存在文本文档中的数据符合一定的格式,通过 ...
- 使用Python中的HTMLParser、cookielib抓取和解析网页、从HTML文档中提取链接、图像、文本、Cookies(二)(转)
对搜索引擎.文件索引.文档转换.数据检索.站点备份或迁移等应用程序来说,经常用到对网页(即HTML文件)的解析处理.事实上,通过 Python语言提供的各种模块,我们无需借助Web服务器或者Web浏览 ...
- 【python】使用HTMLParser、cookielib抓取和解析网页、从HTML文档中提取链接、图像、文本、Cookies
一.从HTML文档中提取链接 模块HTMLParser,该模块使我们能够根据HTML文档中的标签来简洁.高效地解析HTML文档. 处理HTML文档的时候,我们常常需要从其中提取出所有的链接.使用HTM ...
- python、java、ruby、node等如何提取office文档中的内容?
我相信大家都有过这样的需求,把doc.ppt.excel.pdf.txt中的文本内容提取出来.提取出来的文本内容可用于文档内容的全文索引,文档的基本内容摘要等.在度娘上搜索“如何提取文档内容”,确实有 ...
- Python实现读取Excel文档中的配置并下载软件包
问题:现在遇到这样一个问题,服务器存储了很多软件包,这些包输入不同的产品,每个产品都有自己的配置,互相交叉,那么到底某一产品所有配置的软件包下载后,占用多大空间呢? 分析:从这个问题入手,了解到:软件 ...
随机推荐
- Android开发环境搭建
导读: 学习Android开发第一步就是搭建Android开发环境. 1.安装JDK JDK(Java SE Development Kit)是Java的开发工具集.SE表示标准版. JRE(Java ...
- mysql复习相关
Mysql相关 mysql增删改查 我们需要修改数据表名或者修改数据表字段时,就需要使用到Mysql Alter命令 删除,添加或修改表字段 alter table student drop regi ...
- linux大文件分割 split命令
inux split 命令 功能说明:切割文件. 语 法:split [--help][--version][-][-b ][-C ][-l ][要切割的文件][输出文件名] 补充说明:split可将 ...
- 海拔高度图*.dem文件的读取—vtkDEMReader
vtkDEMReader reads digital elevation files and creates image data. Digital elevation files are produ ...
- 通过代码自定义cell(cell的高度不一致,比如微博)
1.新建一个继承自UITableViewCell的类 2.重写initWithStyle:reuseIdentifier:方法 (先要调用父控件的nitWithStyle:reuseIdentifie ...
- 弹框控件 UIAlertView UIActionSheet
// 创建弹框 从底部弹出,一般用于危险操作 UIActionSheet *sheet = [[UIActionSheet alloc] initWithTitle:@"恭喜通关" ...
- mybatis逆向工程生成JavaBean、dao、mapper generatorSqlmapCustom
import java.io.File; import java.util.ArrayList; import java.util.List; import org.mybatis.generator ...
- 第二篇 基于.net搭建热插拔式web框架(沙箱的构建)
上周五写了一个实现原理篇,在评论中看到有朋友也遇到了我的问题,真的是有种他乡遇知己的感觉,整个系列我一定会坚持写完,并在最后把代码开源到git中.上一篇文章很多人看了以后,都表示不解,觉得不知道我到底 ...
- Sicily 1153: 马的周游问题(DFS+剪枝)
这道题没有找到一条回路,所以不能跟1152一样用数组储存后输出.我采用的方法是DFS加剪枝,直接DFS搜索会超时,优化的方法是在搜索是优先走出度小的路径,比如move1和move2都可以走,但是如走了 ...
- word20161223
UAM, user authentication module / 用户身份验证模块 UBR, unspecified bit rate / 未指定的传输率 UCS, Unicode Characte ...