反序迭代一个序列

在列表中,如果我们要将列表反向迭代通常使用reverse()。但这个方法有个缺陷就是会改变列表。
因此,我们推荐使用reversed(),它会返回一个迭代器。这里,我们可以实现__reversed__()解决反向
迭代问题。
 

class FloatRange:

    def __init__(self,start,end,step):
        self.start = start
        self.end = end
        self.step = step

    def __iter__(self): #正向迭代
        t = self.start
        while round(t,2)<=round(self.end,2):
            yield t
            t+=self.step


    def __reversed__(self):  #反向迭代
        t= self.end
        while round(t,2)>=round(self.start,2):
            yield t
            t-=self.step

if __name__ == '__main__':
    for x in FloatRange(3.0,4.0,10.0):
        print(x)  
    for x in reversed(FloatRange(3.0,4.0,10.0)):  #第一次遍历取走了3.0 所以此时只剩()4.0,10.0)
        print(x)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值