Misleading description of [i:j:k] slicing?
Raoul Gough
RaoulGough at yahoo.co.uk
Thu Aug 21 17:49:16 CEST 2003
As of Python 2.3, Section 2.2.6 (Sequence Types) describes slices
which have a specified step (to omit some indexes in beteween), using
the notation s[i:j:k]. The note about how this works says:
"The slice of s from i to j with step k is defined as the sequence
of items with index x = i + n*k such that 0 <= n < abs(i-j). [...]"
Seems to me that "0 <= n < abs(i-j)" is wrong, since the range of n
gets multiplied by k. I would suggest that it should be something
like:
"x = i + n, such that n is a multiple of k and 0 <= n < abs(i-j)"
or maybe better
"x = i + n*k, 0 <= n < ((j-i) / k)"
(Requiring j>i for positive k and j<i for negative k). I've tested the
implementation as follows:
>>> x=[0,1,2,3,4,5,6,7,8,9]
>>> print x[0:5:2]
[0, 2, 4] # Would print [0, 2, 4, 6, 8] according to doc?
>>> print x[2:5:-2]
[] # Would print [2, 0, 8] according to doc??
I was going to submit a bug, but then I realised that I might just be
mis-interpreting what the documentation says (or maybe it'd not even
supposed to be so precise a specification). Any comments or
confirmation on this?
--
Raoul Gough
"Let there be one measure for wine throughout our kingdom, and one
measure for ale, and one measure for corn" - Magna Carta
More information about the Python-list
mailing list