Ответ 1
Вы не печатаете 20
в своей функции __getattr__
. Функция находит атрибут make_statement
в экземпляре Child и возвращает это. Как это бывает, этот атрибут является методом, поэтому он может быть вызван. Таким образом, Python вызывает возвращаемый метод, и этот метод затем печатает 20
.
Если вы хотите удалить вызов ()
, он все равно будет работать; мы можем сохранить этот метод и вызвать его отдельно, чтобы напечатать 20
:
>>> person.make_statement
Calling __getattr__: make_statement
<bound method Child.make_statement of <__main__.Child instance at 0x10db5ed88>>
>>> 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