tags:

views:

120

answers:

2

The Data Model section of the Python 3.1 documentation provides the following descriptions for the __int__ and __index__ methods:

object.__int__(self)

Called to implement the built-in [function int()]. Should return a value of the appropriate type.

object.__index__(self)

Called to implement operator.index(). Also called whenever Python needs an integer object (such as in slicing, or in the built-in bin(), hex() and oct() 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. Could someone please explain this or provide an example? Is it safe to just alias __index__ = __int__ in my classes?

A: 

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).

Peter Hansen
+2  A: 

See PEP 357: Allowing Any Object to be Used for Slicing.

The nb_int method is used for coercion and so means somethin 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 using nb_int would be a bad thing is that float objects already define the nb_int method, but float objects should not be used as indexes in a sequence.

Edit: It seems that it was implemented in Python2.5.

Alok