我在 Python 2.6 中使用“新样式”类,但在子类中使用 __getattr__ 时遇到问题。
如果子类实现这样的...
def __getattr__(self, name):
if self.__folderDict.has_key(name):
if name == 'created':
return doSomethingSpecial(self.__folderDict[name])
return self.__folderDict[name]
else:
raise AttributeError()
我不清楚为什么我的属性异常会因对 __name__ 的引用而抛出?
我的理解是 __getattr__ 甚至不应该被调用,并且 __name__ 应该由 __getattribute__ 填充,因为我使用的是新样式?
这是一个更完整的示例...
class Base(object):
@staticmethod
def printMsg(msg, var):
print msg + str(var)
return
def printName(self):
Base.printMsg('#', self.__name__)
return
class Derived(Base):
def __getattr__(self, name):
if self.__testDict.has_key(name):
return self.__testDict[name]
else:
raise AttributeError()
__testDict = {'userid': 4098}
d = Derived()
print d.userid
d.printName()
结果是...
4098
Traceback (most recent call last):
File "D:/.../Scratch/scratch01.py", line 24, in <module>
d.printName()
File "D:/.../Scratch/scratch01.py", line 17, in __getattr__
raise AttributeError()
AttributeError
最佳答案
__name__
是为类对象预定义的,而不是实例,并且在尝试读取它之前,您不会在任何地方定义 __name__
。因此 _getattr__
被调用(因为 __name__
无法通过正常查找找到)并导致异常。我怀疑你真正想要的是:
...
def printName(self):
Base.printMsg('#', self.__class__.__name__)
return
...
关于python __getattr__ 和 __name__,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9751339/