Defining class attributes + inheritance
Martin De Kauwe
mdekauwe at gmail.com
Tue Mar 8 22:15:11 EST 2011
On Mar 9, 12:53 pm, "Rhodri James" <rho... at wildebst.demon.co.uk>
wrote:
> On Wed, 09 Mar 2011 01:00:29 -0000, Martin De Kauwe <mdeka... at gmail.com>
> wrote:
>
> > class BaseClass(object):
> > def __init__(self, a, b, c, d):
> > self.a = a
> > self.b = b
> > self.c = c
> > self.d = d
>
> > class NewClass(BaseClass):
> > def __init__(self):
> > super(NewClass, self).__init__(new)
> > self.new = new
> > print self.new
>
> Two things leap out immediately. First, BaseClass.__init__ takes four
> parameters besides `self`, but when you call it you only give it one
> parameter, `new`. It's not going to like that. Second, where did `new`
> come from? It's not a parameter to NewClass.__init__, and it doesn't seem
> to be a global. That's not going to work well either.
>
> However neither of these things are what the traceback is complaining
> about.
>
> > if __name__ == "__main__":
>
> > A = PreviousClass(1, 2, 3, 4, 5)
> > B = NewClass(1, 2, 3, 4, 5)
>
> > $ python test.py
> > Traceback (most recent call last):
> > File "model_data.py", line 29, in <module>
> > B = NewClass(1, 2, 3, 4, 5)
> > TypeError: __init__() takes exactly 1 argument (6 given)
>
> When you create your NewClass, you give it five parameters (1, 2, 3, 4, 5)
> plus the implicit `self`, which is the "(6 given)" part of the message.
> However NewClass.__init__ takes no parameters aside from `self` (i.e. it
> "takes exactly 1 argument"). There's a mismatch between what you've told
> NewClass.__init__ to expect and what you actually deliver to it.
>
> The point that may be confusing you is that NewClass.__init__ knows
> nothing at all about BaseClass.__init__. It doesn't inherit parameters
> from it or anything magical like that; you have to tell it everything. If
> you want parameters to pass from NewClass.__init__ to BaseClass.__init__
> you will have to provide them somehow. In this case, I think what you
> meant was something like this:
>
> class NewClass(BaseClass):
> def __init__(self, a, b, c, d, new):
> super(NewClass, self).__init__(a, b, c, d)
> self.new = new
> # etc
>
> --
> Rhodri James *-* Wildebeest Herder to the Masses
Yep that was it, I think I misunderstood and assumed it knew about
stuff in the BaseClass constructor. All makes sense now!
More information about the Python-list
mailing list