what is the "/" mean in __init__(self, /, *args, **kwargs) ?
Terry Reedy
tjreedy at udel.edu
Thu Aug 14 00:03:16 EDT 2014
On 8/13/2014 10:20 PM, Ethan Furman wrote:
> On 08/13/2014 07:01 PM, luofeiyu wrote:
>>>>> help(int.__init__)
>> Help on wrapper_descriptor:
>>
>> __init__(self, /, *args, **kwargs)
>> Initialize self. See help(type(self)) for accurate signature.
>>
>> what is the "/" mean in __init__(self, /, *args, **kwargs) ?
>
> The '/' means that all arguments before it must be positional only.
In particular, int.__init__(self = <subclass instance>) will not work
because 'self' is positional only. (I don't think int.__init__ actually
does anything, but a subclass of int might call it.)
> This looks like an artifact of the new Argument Clinic for C code.
>
> For example, if this also worked at the Python level, you could say:
>
> def some_func(this, that, /, spam, eggs, *, foo, bar):
> pass
>
> Meaning that the first two parameters could not be specified by name,
> the next two could be either name or position, and the last two by name
> only.
>
> Oh, and the * is valid Python now (the / is not -- it's solely a
> documentation feature at this point).
I hope / will be valid Python in 3.5.
--
Terry Jan Reedy
More information about the Python-list
mailing list