views:

45

answers:

2

I am using this simple example to understand Python's getattr function:

In [25]: class Foo:
   ....:     def __getattr__(self, name):
   ....:         print name
   ....:         
   ....:         

In [26]: f = Foo()

In [27]: f.bar
bar
bar

Why is bar printed twice? Using Python 2.6.5.

+3  A: 

You're also using IPython. The stock CPython REPL doesn't exhibit this behavior.

Ignacio Vazquez-Abrams
+6  A: 

I think it's due to IPython.

To "fix" it, you have to disable autocall: %autocall 0

It's an inevitable side-effect of %autocall: since it has to analyze the object in the command line to see if it's callable, python triggers getattr calls on it.

Source: http://mail.scipy.org/pipermail/ipython-user/2008-June/005562.html

Coding District
Thanks for the details!
thebossman