如果我从中执行此操作的函数是实例的类派生的基类,如何找出在Python中创建对象实例的类的名称?
想到也许检查模块可能在这里帮助了我,但它似乎没有给我我想要的东西.如果没有解析__class__
成员,我不知道如何获取这些信息.
你有没有尝试过__name__
这门课程的属性?ie type(x).__name__
会给你这个班级的名字,我认为这就是你想要的.
>>> import itertools >>> x = itertools.count(0) >>> type(x).__name__ 'count'
此方法仅适用于新样式的类.您的代码可能会使用一些旧式类.以下适用于:
x.__class__.__name__
你想把类的名字作为字符串吗?
instance.__class__.__name__
type()?
>>> class A(object): ... def whoami(self): ... print type(self).__name__ ... >>> >>> class B(A): ... pass ... >>> >>> >>> o = B() >>> o.whoami() 'B' >>>
class A: pass a = A() str(a.__class__)
上面的示例代码(当在交互式解释器中输入时)将产生'__main__.A'
,而不是在调用属性时'A'
产生的代码__name__
.只需将结果传递A.__class__
给str
构造函数,就可以为您处理解析.但是,如果您想要更明确的内容,也可以使用以下代码.
"{0}.{1}".format(a.__class__.__module__,a.__class__.__name__)
如果您在单独的模块中定义了具有相同名称的类,则此行为更可取.
上面提供的示例代码在Python 2.7.5中进行了测试.
type(instance).__name__ != instance.__class__.__name #if class A is defined like class A(): ... type(instance) == instance.__class__ #if class A is defined like class A(object): ...
例:
>>> class aclass(object): ... pass ... >>> a = aclass() >>> type(a)>>> a.__class__ >>> >>> type(a).__name__ 'aclass' >>> >>> a.__class__.__name__ 'aclass' >>> >>> class bclass(): ... pass ... >>> b = bclass() >>> >>> type(b) >>> b.__class__ >>> type(b).__name__ 'instance' >>> >>> b.__class__.__name__ 'bclass' >>>
好问题.
这是一个基于GHZ的简单示例,它可以帮助某些人:
>>> class person(object): def init(self,name): self.name=name def info(self) print "My name is {0}, I am a {1}".format(self.name,self.__class__.__name__) >>> bob = person(name='Robert') >>> bob.info() My name is Robert, I am a person
或者你可以使用classmethod
装饰器:
class A:
@classmethod
def get_classname(cls):
return cls.__name__
def use_classname(self):
return self.get_classname()
用法:
>>> A.get_classname()
'A'
>>> a = A()
>>> a.get_classname()
'A'
>>> a.use_classname()
'A'
除了获取特殊__name__
属性外,您可能会发现自己需要给定类/函数的合格名称。这是通过获取类型来完成的__qualname__
。
在大多数情况下,它们将完全相同,但是在处理嵌套类/方法时,它们在输出中会有所不同。例如:
class Spam: def meth(self): pass class Bar: pass >>> s = Spam() >>> type(s).__name__ 'Spam' >>> type(s).__qualname__ 'Spam' >>> type(s).Bar.__name__ # type not needed here 'Bar' >>> type(s).Bar.__qualname__ # type not needed here 'Spam.Bar' >>> type(s).meth.__name__ 'meth' >>> type(s).meth.__qualname__ 'Spam.meth'
由于自省是您所要追求的,因此始终可能需要考虑这一点。