这是我的代码:
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 + 1def superPrize(purchases,d): return List(Prizes(purchases,d))
用法示例:
superPrize([12,43,13,465,1,13],2,3)
输出应该是:
[4]
但实际输出是:
[None,None,4,None].
为什么会这样?最佳答案你的问题是__next__的实现.当Python调用__next__时,它总是期望返回值.但是,在您的情况下,看起来您可能并不总是每次调用都有返回值.因此,Python使用函数的默认返回值 – 无:
你需要一些方法来保持程序控制在__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所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)