【流畅的Python】--Iterable和Iterator的理解

文章目录


前言

【流畅的Python】系列文章,是笔者学习流畅的Python一书时的笔记,特此记录,文中不足之处,请大家指正。文章内容参考了网上的一些博客,如有侵权,请联系笔者删除。


一、Iterable和Iterator的区别?

Iterable(可迭代对象): 有迭代能力的对象。如果一个类,实现了__iter__,那么就认为它有迭代能力,称为Iterable类。这个类通常必须返回一个实现了__next__的对象,如果自己实现了,你可以返回self, 当然这个返回值不是必须的。

可以使用instance()判断一个对象是否是Iterable对象

可以直接作用于for循环的对象统称为可迭代对象:Iterable

Iterator(迭代器):迭代器(当然也是Iteable),同时实现了__iter____next__方法的类,缺少任何一个都不算是Iterator

迭代器:不仅实现了__iter__,还实现了__next__

示例代码:

python 复制代码
from collections.abc import *

class A:
    def __next__(self):
        return 1
# class B:
#     def __iter__(self):
#         return A()
class B:
    def __iter__(self):
        return A()
    def __next__(self):
        return None


a = A()
b = B()
print(isinstance(a, Iterable))
print(isinstance(a, Iterator))

print(isinstance(b, Iterable))
print(isinstance(b, Iterator))

输出:

python 复制代码
False
False
True 
True

补充说明1:iter()函数,用iter函数可以返回一个可迭代对象的迭代器

代码如下(示例):

for i in a

其实在python内部进行了类似如下的转换

for i in iter(a)

那么iter()返回的是什么呢,就是一个迭代对象,它主要映射了类里面的__iter__函数,此函数返回的是一个实现了__next__的对象。

补充说明2:迭代器只能往前取值,不能后退

python 复制代码
class myRanges():
    def __init__(self, end):
        self.start = 0
        self.end = end
    def __next__(self):
        if self.start < self.end:
            curr = self.start
            self.start = self.start +1
            return curr
        else:
            raise StopIteration
    
    def __next__(self):
        return self
    
from collections.abc import *
myra = myRanges(5)
print(isinstance(myra, Iterable))

输出:

python 复制代码
False

二、参考文章

python之迭代器(iterator)详解
python iterable和iterator区别

相关推荐
曲幽5 小时前
FastAPI + PostgreSQL 实战:从入门到不踩坑,一次讲透
python·sql·postgresql·fastapi·web·postgres·db·asyncpg
用户83562907805110 小时前
使用 C# 在 Excel 中创建数据透视表
后端·python
码路飞13 小时前
FastMCP 实战:一个 .py 文件,给 Claude Code 装上 3 个超实用工具
python·ai编程·mcp
dev派15 小时前
AI Agent 系统中的常用 Workflow 模式(2) Evaluator-Optimizer模式
python·langchain
前端付豪17 小时前
AI 数学辅导老师项目构想和初始化
前端·后端·python
用户03321266636717 小时前
将 PDF 文档转换为图片【Python 教程】
python
悟空爬虫18 小时前
UV实战教程,我啥要从Anaconda切换到uv来管理包?
python
dev派19 小时前
AI Agent 系统中的常用 Workflow 模式(1)
python·langchain
明月_清风20 小时前
从“能用”到“专业”:构建生产级装饰器与三层逻辑拆解
后端·python
曲幽1 天前
数据库实战:FastAPI + SQLAlchemy 2.0 + Alembic 从零搭建,踩坑实录
python·fastapi·web·sqlalchemy·db·asyncio·alembic