你不是在__getattr__函数中打印20.该函数在Child实例上找到make_statement属性并返回.发生这种情况,该属性是一种方法,因此它是可调用的. Python因此调用返回的方法,然后打印20.
如果你要删除()调用,它仍然可以工作;我们可以存储方法并单独打电话给20打印:
>>> person.make_statement
Calling __getattr__: make_statement
>
>>> ms = person.make_statement
Calling __getattr__: make_statement
>>> ms()
I am an instance of Child with age 10
如果你必须看到参数,你必须返回一个包装函数:
def __getattr__(self,attr):
print("Calling __getattr__: "+attr)
if hasattr(self.child,attr):
def wrapper(*args,**kw):
print('called with %r and %r' % (args,kw))
return getattr(self.child,attr)(*args,**kw)
return wrapper
raise AttributeError(attr)
现在这样做:
>>> person.make_statement(20)
Calling __getattr__: make_statement
called with (20,) and {}
I am an instance of Child with age 20