在Python中获取实例的类名

我如何find在Python中创build对象的实例的类的名称,如果我这样做的函数是派生实例的类的基类?

在想,也许检查模块可能帮助我在这里,但它似乎并没有给我我想要的。 并没有parsing__class__成员,我不知道如何得到这个信息。

你有没有尝试过类的__name__属性? 即type(x).__name__将给你的类的名称,我认为是你想要的。

 >>> import itertools >>> x = itertools.count(0) >>> type(x).__name__ 'count' 

此方法仅适用于新式类 。 你的代码可能会使用一些旧式的类。 以下作品适用于两者:

 x.__class__.__name__ 

你想把这个类的名字当成一个string吗?

 instance.__class__.__name__ 

type()?

 >>> class A(object): ... def whoami(self): ... print type(self).__name__ ... >>> >>> class B(A): ... pass ... >>> >>> >>> o = B() >>> o.whoami() 'B' >>> 
 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) <class '__main__.aclass'> >>> a.__class__ <class '__main__.aclass'> >>> >>> type(a).__name__ 'aclass' >>> >>> a.__class__.__name__ 'aclass' >>> >>> class bclass(): ... pass ... >>> b = bclass() >>> >>> type(b) <type 'instance'> >>> b.__class__ <class __main__.bclass at 0xb765047c> >>> type(b).__name__ 'instance' >>> >>> b.__class__.__name__ 'bclass' >>> 
 class A: pass a = A() str(a.__class__) 

上面的示例代码(当在交互式解释器中input时)将生成'__main__.A' ,而不是在调用__name__属性时产生的'A' 。 通过简单地将A.__class__的结果传递给str构造函数,就可以为您处理parsing。 不过,如果你想要更明确的东西,你也可以使用下面的代码。

 "{0}.{1}".format(a.__class__.__module__,a.__class__.__name__) 

如果您在单独的模块中定义具有相同名称的类,则此行为可能更好。

上面提供的示例代码在Python 2.7.5中进行了testing。

好问题。

下面是一个基于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__属性,你可能会发现自己需要一个给定的类/函数的限定名称 。 这是通过抓取types__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' 

既然内省是你以后的事情,那么你总是可以考虑。