我对isinstance()
在Python中的工作原理感到有点迷茫。我之前使用过这个功能,行为很明显,直到现在。
一点背景。我有一个类Classifier
,它有一个方法set_kernel
,可以将字符串或内核作为参数。我正在从main函数创建一个名为k
的内核类型的对象。当我使用isinstance(k, Kernel)
时,答案是True
。但是,如果我将k
作为参数传递给分类器,然后我在函数内部执行相同的检查,则返回False
。
关于这里发生了什么的任何线索?我附上一些代码片段以使其更清晰:
class Kernel(object):
pass
class Gaussian(Kernel):
pass
class Classifier():
def set_kernel(kernel, *args):
print isinstance(kernel, Kernel) # This prints False
k = Gaussian() # This is a son of Kernel
print isinstance(k, Kernel) # This prints True
c = Classifier()
c.set_kernel(k) # This prints False, check above
谢谢!
编辑1:我改进了编码并清理了与问题本身无关的所有事情。
答案 0 :(得分:3)
如果您的set_kernel
函数不,则staticmethod
如果您在实例上调用此函数,则第一个参数是实例。例如见:
class Classifier():
def set_kernel(kernel, *args):
print(kernel)
print(isinstance(kernel, int))
>>> k = 10
>>> print(k)
10
>>> print(isinstance(k, int))
True
>>> c = Classifier()
>>> c.set_kernel(k)
<__main__.Classifier object at 0x0000020FABD0FDA0>
False
如果您将其设为staticmethod
,则“工作”:
class Classifier():
@staticmethod
def set_kernel(kernel, *args):
print(kernel)
print(isinstance(kernel, int))
>>> k = 10
>>> print(k)
10
>>> print(isinstance(k, int))
True
>>> c = Classifier()
>>> c.set_kernel(k)
10
True
或者如果您不希望它是静态的,请为该实例插入另一个参数,通常在参数列表中称为“self”:
class Classifier():
def set_kernel(self, kernel, *args):
print(kernel)
print(isinstance(kernel, int))
答案 1 :(得分:3)
您忘记了self
参数:
class Classifier():
def set_kernel(kernel, *args):
print isinstance(kernel, Kernel)
这意味着kernel
不是内核。作为第一个位置参数,kernel
扮演self
的角色,因此它实际上是分类器。传递给方法的内核最终成为args
的第一个元素。