How can I make an instance of a class act like a dictionary?

Benjamin Kaplan benjamin.kaplan at case.edu
Mon Feb 27 15:37:15 EST 2012


On Mon, Feb 27, 2012 at 3:09 PM, John Salerno <johnjsal at gmail.com> wrote:
> On Feb 27, 1:39 am, Chris Rebert <c... at rebertia.com> wrote:
>> On Sun, Feb 26, 2012 at 11:24 PM, John Salerno <johnj... at gmail.com> wrote:
>> > Hi everyone. I created a custom class and had it inherit from the
>> > "dict" class, and then I have an __init__ method like this:
>>
>> > def __init__(self):
>> >        self = create()
>>
>> > The create function creates and returns a dictionary object. Needless
>> > to say, this is not working. When I create an instance of the above
>> > class, it is simply an empty dictionary rather than the populated
>> > dictionary being created by the create function. Am I doing the
>> > inheritance wrong, or am I getting the above syntax wrong by assigning
>> > the return value to self?
>>
>> Assignment to `self` has no effect outside the method in question;
>> Python uses call-by-object (http://effbot.org/zone/call-by-object.htm
>> ) for argument passing.
>> Even in something like C++, I believe assignment to `this` doesn't work.
>>
>> > I know I could do self.variable = create() and that works fine, but I
>> > thought it would be better (and cleaner) simply to use the instance
>> > itself as the dictionary, rather than have to go through an instance
>> > variable.
>>
>> Call the superclass (i.e. dict's) initializer (which you ought to be
>> doing anyway):
>>     super(YourClass, self).__init__(create())
>>
>> Cheers,
>> Chris
>> --http://rebertia.com
>
> Thanks. This ended up working:
>
> def __init__(self):
>        self = super().__init__(create_board())
>
> Is that what you meant for me to do? Why did assigning to self work in
> this case, but not the original case?


It didn't do anything and still isn't doing anything.

In Python, names are assigned to objects


self -> <Object1>
              ^
foo -------|

Reassigning a name does not change the value, so
self = create()

Just makes an object2

self -> <Object2>

foo ---> <Object1>

The reason it's working here is because the super().__init__() call
modifies the existing object in place. It returns None, so you're
setting self = None but that doesn't matter because of what I
explained before about how assigning to self doesn't actually change
anything.
> --
> http://mail.python.org/mailman/listinfo/python-list



More information about the Python-list mailing list