python迭代-如何实现反向迭代

如何实现反向迭代

问题举例

实现一个连续浮点数发生器FloatRange,根据给定范围(start, end)和步进值(step)

产生一系列连续的浮点数,如FloatRange(3.0, 4.0, 0.2)可产生序列:

正向:3.0>3.2>3.4>3.6>3.8>4.0

反向:4.0>3.8>3.6>3.4>3.2>3.0

 

分析

(1)列表的reverse()方法

list1 = [1, 2, 3, 4, 5]
list1.reverse()
for x in list1:
    print(x) # 5 4 3 2 1

改变了原列表,在某些情况下是不被允许的

 

(2)切片操作

list1 = [1, 2, 3, 4, 5]
list2 = list1[::-1]
for x in list2:
    print(x) # 5 4 3 2 1

创建和原列表等大的列表,浪费内存空间

 

解决思路

实现反向迭代协议的__reversesd__方法,它返回一个反向迭代器

 

代码

from decimal import Decimal

class FloatRange:
    def __init__(self, a, b, step):
        self.a = Decimal(str(a))
        self.b = Decimal(str(b))
        self.step = Decimal(str(step))

    def __iter__(self):
        t = self.a
        while t <= self.b:
            yield float(t)
            t += self.step

    def __reversed__(self):
        t = self.b
        while t >= self.a:
            yield float(t)
            t -= self.step

fr = FloatRange(3.0, 4.0, 0.2)
for x in fr:
    print(x)
print('-' * 20)
for x in reversed(fr):
    print(x)

 

参考资料:python3实用编程技巧进阶

posted @ 2019-04-25 22:39  可口可乐嗨  阅读(911)  评论(0编辑  收藏  举报
levels of contents