如何实现反向迭代
问题举例
实现一个连续浮点数发生器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实用编程技巧进阶