[Python-ideas] New 3.x restriction on number of keyword arguments
Nick Coghlan
ncoghlan at gmail.com
Sat Sep 18 09:28:42 CEST 2010
On Sat, Sep 18, 2010 at 7:11 AM, Antoine Pitrou <solipsis at pitrou.net> wrote:
> On Fri, 17 Sep 2010 13:00:08 -0700
> Raymond Hettinger
> <raymond.hettinger at gmail.com> wrote:
>> One of the use cases for named tuples is to have them be automatically created from a SQL
>> query or CSV header. Sometimes (but not often), those can have a huge number of columns. In
>> Python 2.x, it worked just fine -- we had a test for a named tuple with 5000 fields. In
>> Python 3.x, there is a SyntaxError when there are more than 255 fields.
>
> I don't understand your explanation. You can't pass a namedtuple using
> the **kw convention:
But you do need to *initialise* the named tuple after you create it.
If it's a big tuple, then all of those field values need to be passed
in either as positional arguments or as keyword arguments. A
restriction to 255 parameters means that named tuples with more than
255 fields become a lot less useful.
Merging the parameter count into the opcode as an optimisation when
the number of parameters is < 256 is fine. *Disallowing* parameter
counts >= 255 is not.
Cheers,
Nick.
--
Nick Coghlan | ncoghlan at gmail.com | Brisbane, Australia
More information about the Python-ideas
mailing list