类中的iter与next,遍历与迭代

`'''
关于迭代与遍历
'''
class Person:
    def __init__(self):
        self.result = 1

    def __iter__(self): #返回一个迭代器,达到遍历的效果  有iter就是可迭代对象,collections.Iterable,但是有iter不一定是迭代器,有iter和next的才是迭代器,所以可迭代的不一定是迭代器
        self.result=1  #不加这句话的话 只能遍历一次,结束后指针就在截止边界了。加上之后每一次for in 都调用iter,都重置了result,就可以重复使用了
        # return iter([1,2,3,4,5])  #iter()把可遍历的东西变成迭代器
        return self #需要把self变成迭代器,如何实现?——使用__next__(想要这个类是迭代器 iter和next都要有)
    def __next__(self):
        self.result+=1
        if self.result>=6:
            raise StopIteration('stop')
        return self.result
p=Person()
for i in p: #遍历的操作调用的是__iter__
    print(i)

print(next(p))  #next调用的是__next__
print(next(p))
print(next(p))
print(next(p))
import collections
print(isinstance(p,collections.abc.Iterator))
for i in p:  #只能遍历一次,结束后指针就在截止边界了,只需要在iter里面重置截止条件,就能再次进行遍历了(仅限for in,不能next())
    print(i)

#也可以:
class Person:
    def __init__(self):
        self.result = 1
    def __getitem__(self, item):
        self.result += 1
        if self.result >= 6:
            raise StopIteration('stop')
        return self.result
    def __call__(self, *args, **kwargs):
        self.result += 1
        if self.result >= 6:
            raise StopIteration('stop')
        return self.result

p=Person()
pt=iter(p) #这时候也变成了迭代器
print(pt)
for i in pt:
    print(i)

pt=iter(p,5) #当p是5的时候就会停止迭代,但是iter会直接调用p,但是没有__call__的类不是可调用对象,所以要加上call  如果只是iter(p)就不需要定义call了
for i in pt:
    print(i)`
  • 13
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值