我正在学习python,最后还是和工厂一起玩。下面的代码给了我以下错误,我不知道为什么。
Traceback (most recent call last):
File "C:\py_Lab\Factory.py", line 38, in <module>
print(MyFactory("Ham").x)
File "C:\py_Lab\Factory.py", line 30, in MyFactory
if cls.Check(myStr):
TypeError: Check() missing 1 required positional argument: 'myStr'
工厂定义假定循环遍历基类的子类,并使用子类中的Check()
定义来选择要运行的类。我非常确定参数'myStr'
应该在哪里,并且我在工厂的实例中放置了一个参数。这个错误是由python编译的方式引起的吗?我在python 3.5
个电脑上运行Windows 8
。
class BaseClass(object):
pass
class AltBaseClass(object):
pass
class C1(BaseClass, AltBaseClass):
def __init__(self, *args, **kwargs):
self.x = 1
def Check(self, myStr, *args, **kwargs):
return myStr == "Ham"
class C2(BaseClass, AltBaseClass):
def __init__(self, *args, **kwargs):
self.x = 30
def Check(self, myStr, *args, **kwargs):
return myStr == "Sandwich"
class C3(BaseClass, AltBaseClass):
def __init__(self, *args, **kwargs):
self.x = 70
def Check(self, myStr, *args, **kwargs):
return myStr == "Pancake"
def MyFactory(myStr):
for cls in BaseClass.__subclasses__():
if cls.Check(myStr):
return cls()
def OthrFactory(myStr):
for cls in AltBaseClass.__subclasses__():
if cls.Check(myStr):
return cls()
print(MyFactory("Ham").x)
print(OthrFactory("Sandwich").x)
print(OthrFactory("Pancake").x)
答案 0 :(得分:0)
您应该使用Check()
装饰器使@staticmethod
为静态。也许@classmethod
也可能有用。
@staticmethod
def Check(myStr, *args, **kwargs):
# ...
pass
这样您就没有self
(一个实例)myStr
被解释为。
答案 1 :(得分:0)
在Check()
处运行cls.Check(myStr)
时,您错过了一个参数。 Check(self, myStr, *args, **kwargs)
需要2个参数,self
和myStr
。因此,运行Check(myStr)
需要第二个参数,按名称,我认为是self
。