The Data Model section of the Python 3.2 documentation provides the following descriptions for the __int__
and __index__
methods:
object.__int__(self)
Called to implement the built-in [function
int()
]. Should return [an integer].
object.__index__(self)
Called to implement
operator.index()
. Also called whenever Python needs an integer object (such as in slicing, or in the built-inbin()
,hex()
andoct()
functions). Must return an integer.
I understand that they're used for different purposes, but I've been unable to figure out why two different methods are necessary. What is the difference between these methods? Is it safe to just alias __index__ = __int__
in my classes?
See PEP 357: Allowing Any Object to be Used for Slicing.
The
nb_int
method is used for coercion and so means something fundamentally different than what is requested here. This PEP proposes a method for something that can already be thought of as an integer communicate that information to Python when it needs an integer. The biggest example of why usingnb_int
would be a bad thing is that float objects already define thenb_int
method, but float objects should not be used as indexes in a sequence.
Edit: It seems that it was implemented in Python 2.5.
I believe you'll find the answer in PEP 357, which has this abstract:
This PEP proposes adding an nb_index slot in PyNumberMethods and an __index__ special method so that arbitrary objects can be used whenever integers are explicitly needed in Python, such as in slice syntax (from which the slot gets its name).
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With