- 译者序
- 前言
- 第1章 问答环节
- 第2章 Python 如何运行程序
- 第3章 如何运行程序
- 第4章 介绍 Python 对象类型
- 第5章 数字
- 第6章 动态类型简介
- 第7章 字符串
- 第8章 列表与字典
- 第9章 元组、文件及其他
- 第10章 Python 语句简介
- 第11章 赋值、表达式和打印
- 第12章 if 测试和语法规则
- 第13章 while 和 for 循环
- 第14章 迭代器和解析,第一部分
- 第15章 文档
- 第16章 函数基础
- 第17章 作用域
- 第18章 参数
- 第19章 函数的高级话题
- 第20章 迭代和解析,第二部分
- 第21章 模块:宏伟蓝图
- 第22章 模块代码编写基础
- 第23章 模块包
- 第24章 高级模块话题
- 第25章 OOP:宏伟蓝图
- 第27章 更多实例
- 第28章 类代码编写细节
- 第29章 运算符重载
- 第30章 类的设计
- 第31章 类的高级主题
- 第32章 异常基础
- 第34章 异常对象
- 第35章 异常的设计
- 第36章 Unicode 和字节字符串
- 字符串基础知识
- Python 的字符串类型
- 文本和二进制文件
- Python 3.0 中的字符串应用
- 转换
- 编码 Unicode 字符串
- 编码非ASCII文本
- 编码和解码非ASCII文本
- 其他 Unicode 编码技术
- 转换编码
- 在 Python 2.6 中编码 Unicode 字符串
- 源文件字符集编码声明
- 使用 Python 3.0 Bytes 对象
- 序列操作
- 创建 bytes 对象的其他方式
- 混合字符串类型
- 使用 Python 3.0(和 Python 2.6)bytearray 对象
- 使用文本文件和二进制文件
- Python 3.0 中的文本和二进制模式
- 类型和内容错误匹配
- 使用 Unicode 文件
- 在 Python 3.0 中处理 BOM
- Python 2.6 中的 Unicode 文件
- Python 3.0 中其他字符串工具的变化
- Struct二进制数据模块
- pickle对象序列化模块
- XML解析工具
- 本章小结
- 本章习题
- 习题解答
- 第37章 管理属性
- 第38章 装饰器
- 第39章 元类
- 附录A 安装和配置
- 附录B 各部分练习题的解答
- 作者介绍
- 封面介绍
手动迭代:iter 和 next
从技术角度来讲,迭代协议还有一点值得注意。当for循环开始时,会通过它传给iter内置函数,以便从可迭代对象中获得一个迭代器,返回的对象含有需要的next方法。如果我们看看for循环内部如何处理列表这类内置序列类型的话,就会变得一目了然了。
最初的一步对于文件来说不是必需的,因为文件对象就是自己的迭代器。也就是说,文件有自己的__next__方法,因此不需要像这样返回一个不同的对象:
列表以及很多其他的内置对象,不是自身的迭代器,因为它们支持多次打开迭代器。对这样的对象,我们必须调用iter来启动迭代:
尽管Python迭代工具自动调用这些函数,我们也可以使用它们来手动地应用迭代协议。如下的交互展示了自动和手动迭代之间的对等性[1]:
要理解这段代码,你需要知道,try语句运行一个动作并且捕获在运行过程中发生的异常(我们将在本书第七部分深入介绍异常)。还应该注意,for循环和其他的迭代环境有时候针对用户定义的类不同地工作,重复地索引一个对象而不是运行迭代协议。等到我们在第29章中学习运算符重载的时候,再介绍这一内容。
注意:版本差异提示:在Python 2.6中,迭代方法叫做X.next()而不是X.__next__()。为了可移植性,next(X)内置函数在Python 2.6中也是可用的(但在更早的版本中不可以),并且,调用Python 2.6的X.next()而不是Python 3.0的X.__next__()。在Python 2.6中所有其他方式中,迭代都是一样地工作的,只是在手动迭代中直接使用X.next()或next(X),而不是Python 3.0的X.__next__()。在Python 2.6之前的版本中,使用手动X.next()调用而不是next(X)。
[1]从技术上讲,for循环调用内部等价的I.__next__,而不是这里所使用的next(I)。这两者之间几乎没有区别,但是,我们将在下一小节中看到,Python 3.0中有一些内置的对象(例如os.popen的结果)支持前者而不支持后者,但仍然可以在for循环中迭代。手动的迭代通常可以使用任何一种调用形式。如果你关注详细情况,Python 3.0中的os.popen结果已经用subprocess模块和一个包装类重新实现,在Python 3.0中,其__getattr__方法不再针对next内置函数所做出的显式__next__获取而调用,而是针对按名称的显式获取而调用,这是我们将在第37章和第38章中学习的一个Python 3.0的修改,它似乎也用到了某些标准库代码。还是在Python 3.0中,相关的Python 2.6调用os.popen2/3/4不再可用,而是使用带有相应参数的subprocess.Popen(参见Python 3.0库手册可以了解新的必需的代码)。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论