概述
这是我的代码:
class Prizes(object):
def __init__(self,purchases,n,d):
self.p = purchases
self.n = n
self.d = d
self.x = 1
def __iter__(self):
return self
def __next__(self):
print(self.x)
if self.x % self.n == 0 and self.p[self.x - 1] % self.d == 0:
self.x = self.x + 1
return self.x - 1
elif self.x > len(self.p):
raise StopIteration
self.x = self.x + 1
def superPrize(purchases,d):
return list(Prizes(purchases,d))
用法示例:
superPrize([12,43,13,465,1,13],2,3)
输出应该是:
[4]
但实际输出是:
[None,None,4,None].
为什么会这样?
你需要一些方法来保持程序控制在__next__中,直到你有一个实际的返回值.这可以使用while循环完成:
def __next__(self):
while True:
if self.x % self.n == 0 and self.p[self.x - 1] % self.d == 0:
self.x = self.x + 1
return self.x - 1
elif self.x > len(self.p):
raise StopIteration
self.x = self.x + 1
总结
以上是编程之家为你收集整理的Python:迭代器返回None全部内容,希望文章能够帮你解决Python:迭代器返回None所遇到的程序开发问题。
如果您也喜欢它,动动您的小指点个赞吧