Python classes: Simplify?
J. Cliff Dyer
jcd at sdf.lonestar.org
Thu Mar 22 14:12:32 EDT 2012
The issue of explicitly naming a "self" parameter has been discussed in
depth on a number of occasions. I recommend a google search for "python
implicit self" for some of the reasons why it exists. Here's what Guido
has to say about it:
http://neopythonic.blogspot.com/2008/10/why-explicit-self-has-to-stay.html
Cheers,
Cliff
On Thu, 2012-03-22 at 13:15 +0000, Andrea Crotti wrote:
> On 03/22/2012 10:51 AM, Steven Lehar wrote:
> > It seems to me that the Python class system is needlessly confusing.
> > Am I missing something?
> >
> >
> > For example in the class Complex given in the documentation
> >
> >
> > class Complex:
> > def __init__(self, realpart, imagpart):
> > self.r = realpart
> > self.i = imagpart
> >
> >
> > x = Complex(3.0, -4.5)
> >
> >
> > I initially found it profoundly confusing that __init__( ) calls for
> > 3 arguments, but you call Complex( ) with 2. Furthermore, why not
> > call the initialization function after the class name as is done in
> > other languages? Isn't that the simplest conceptually? Demonstrating
> > with the above example:
> >
> >
> > class Complex:
> > def Complex(realpart, imagpart):
> > Complex.r = realpart
> > Complex.i = imagpart
> >
> >
> > x = Complex(3.0, -4.5)
> >
> >
> > Is there a good reason why classes cannot be defined that way?
> > (Besides the problem of backward-compatibility)
> >
> >
>
> Some time ago I saw some nasty hack that allowed you to drop the self
> in the method declaration,
> using some crazy metaclass trick, but that's really not a good idea ;)
>
> I agree that is counter-intuitive but just set your editor to do that
> for you and you will be fine..
>
> in my emacs
> - s TAB -> self
> - . TAB -> self.
> - m TAB -> def ${1:method}(self$2):
> $0
>
> so I never actually write the self..
More information about the Python-list
mailing list