我有一个类,它有一个创建类实例的方法。
class Bar:
@classmethod
def create(cls, foo: int):
return cls(foo)
def __init__(self, foo: int) -> None:
pass
当我针对它运行 mypy 时,它显示 mypytest.py:4: error: Too many arguments for "Bar"
对我来说这似乎是一个错误,因为它工作正常
class Bar:
@classmethod
def create(cls, foo):
return cls(foo)
def __init__(self, foo: int) -> None:
pass
我不明白为什么定义参数类型的类方法会破坏实例的创建。我错过了什么吗?
最佳答案
答案很简单,把__init__
方法放在最前面就行了。例如,这很好用:
class Bar:
def __init__(self, foo: int) -> None:
pass
@classmethod
def create(cls, foo: int):
return cls(foo)
由于某些技术原因,如果 __init__
(或 __new__
)不是类定义中的第一个方法,mypy 目前在某些极端情况下会出现意外行为。我想我已经看到了类似的问题,但在 mypy tracker 上找不到问题。
关于python - 为什么 mypy 说我有太多的争论,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47493293/