您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

Python:迭代器返回None

5b51 2022/1/14 8:21:38 python 字数 2048 阅读 517 来源 www.jb51.cc/python

这是我的代码:class Prizes(object): def __init__(self, purchases, n, d): self.p = purchases self.n = n self.d = d self.x = 1 def __iter__(self):

概述

这是我的代码

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所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶