当前位置:编程学堂 > python技巧(9)

python技巧(9)

  • 发布:2023-09-09 17:38

1.列表的反向迭代
l=[1,2,3]
反向1
l.reverse(),缺点此时l被改变了

反向2:切片
s=l[::-1],缺点得到了一个同样大小的列表站占用空间
反向3:
l1=reversed(l)
由于前两种都有不足的地方
我们既要得到一个新的但是不改变原来的列表,又不能占用太多内存,此时可以想到反向迭代器或则反向生成器,当然iter就是正向迭代器

2.创建一个正向和反向迭代器对象(FloatRange类似与xrange(start,end,step))

class FlaotRange():def __init__(self,start,end,step=0.1):self.start=startself.end=endself.step=stepdef __iter__(self):t=self.startif t<=self.end:yeild tt+=self.stepdef __reversed__(self):t=self.endif t>=self.start:yeild tt-=self.step

相关文章