在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'
既然内省是你以后的事情,那么你总是可以考虑。