python 迭代器协议

本文深入解析了Python中迭代器协议的工作原理,包括如何通过实现__iter__和__next__方法使对象变得可迭代。同时,通过斐波那契数列的实现展示了迭代器的应用,对比了迭代器与传统循环方法在生成斐波那契数列时的效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

# 1:迭代器协议是指:对象必须提供一个next方法,
# 执行该方法要么返回迭代中的下一项 ,要么就引起一个StopIteratior异常,
# 以终止迭代(只能往后走不能往前退)
# 2:可迭代对象:实现了迭代器协议的对象
# (如何实现:对象内部定义一个__iter__()方法)
# 3 协议是一种约定,可迭代对象实现了迭代器协议,
# python 的内部工具(如for循环,sum,min,max函数等)使用迭代器协议访问对象
            # for循环的本质:循环所有对象,全部是使用迭代器协议。
l='hello'
for i in range(len(l)):
    print(i,l[i])
class Foo:
    def __init__(self,n):
        self.n=n
    def __iter__(self): #所有不可迭代的 加入iter 之后 都变得可迭代
        return self
    def __next__(self):
        if self.n==100:
            raise StopIteration("终止")
        self.n+=1
        return self.n #运行过后都保存在 self.n里
f1=Foo(10)
# print(f1.__next__())
# print(f1.__next__())
# print(f1.__next__())
# print(f1.__next__())
for i in f1:
    print(i)
   #斐波那契数列
class Fib:
    def __init__(self):
        self.a=1
        self._b=1
    def __iter__(self):
        return self
    def __next__(self):
        if self.a>100:
            raise StopIteration("终止")
        self.a,self._b=self._b,self.a + self._b
        return self.a
f1=Fib()
for i in f1:    #只有字典才能 用循环中的 按照序号一一对应输出
    print(i)
print("___"*20)
# print(f1.__next__())
# print(f1.__next__())
# print(f1.__next__())
# print(f1.__next__())
# print(f1.__next__())
#方法二
a=0
b=1
while b<=100:
    print(b)
    a ,b= b,a+b
def fibNum(n):          #斐波那契数列
    a, b = 0, 1
    for i in range(n):
        b, a = a+b, b
    return b
n = int(input(">>:"))
if n == 1:
    print(0)
elif n == 2:
    print(1)
else:
    print(fibNum(n-2))
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值