[Python-Dev] Error message for wrong number of arguments
Jeroen Demeyer
J.Demeyer at UGent.be
Mon Jul 30 08:12:22 EDT 2018
Hello,
I noticed an inconsistency in the error messages for the number of
arguments to a method call. For Python methods, the "self" argument is
counted. For built-in methods, the "self" argument is *not* counted:
>>> class mylist(list):
... def append(self, val): super().append(val)
>>> f = list().append
>>> f(1,2)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: append() takes exactly one argument (2 given)
>>> g = mylist().append
>>> g(1,2)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: append() takes 2 positional arguments but 3 were given
I think it has been argued before that it's a feature that self is
counted. So I consider the error message for list().append a bug. This
is one of the many oddities I noticed while working on improving
built-in functions.
Would you agree to change the error message for built-in methods to be
closer to Python methods?
Jeroen.
More information about the Python-Dev
mailing list