summaryrefslogtreecommitdiffstats
path: root/Doc/lib
diff options
context:
space:
mode:
authorFred Drake <fdrake@acm.org>2000-08-14 15:37:59 (GMT)
committerFred Drake <fdrake@acm.org>2000-08-14 15:37:59 (GMT)
commit107b9679c482e99af11f5867d8267809764a1b48 (patch)
treeb3165f9d28c48bb16e21246debe9320bc5175bae /Doc/lib
parentb7520774e2d7072e765436842ccf914ed7fd03ad (diff)
downloadcpython-107b9679c482e99af11f5867d8267809764a1b48.zip
cpython-107b9679c482e99af11f5867d8267809764a1b48.tar.gz
cpython-107b9679c482e99af11f5867d8267809764a1b48.tar.bz2
Document the range type, as suggested by Denis S. Otkidach
<den@analyt.chem.msu.ru>.
Diffstat (limited to 'Doc/lib')
-rw-r--r--Doc/lib/libstdtypes.tex28
1 files changed, 24 insertions, 4 deletions
diff --git a/Doc/lib/libstdtypes.tex b/Doc/lib/libstdtypes.tex
index fdbb557..5ce8c0c 100644
--- a/Doc/lib/libstdtypes.tex
+++ b/Doc/lib/libstdtypes.tex
@@ -312,8 +312,8 @@ division by \code{pow(2, \var{n})} without overflow check.
\subsection{Sequence Types \label{typesseq}}
-There are five sequence types: strings, Unicode strings, lists,
-tuples, and buffers.
+There are six sequence types: strings, Unicode strings, lists,
+tuples, buffers, and ranges.
Strings literals are written in single or double quotes:
\code{'xyzzy'}, \code{"frobozz"}. See chapter 2 of the
@@ -327,7 +327,10 @@ or without enclosing parentheses, but an empty tuple must have the
enclosing parentheses, e.g., \code{a, b, c} or \code{()}. A single
item tuple must have a trailing comma, e.g., \code{(d,)}. Buffers are
not directly support by Python syntax, but can created by calling the
-builtin function \function{buffer()}.\bifuncindex{buffer}
+builtin function \function{buffer()}.\bifuncindex{buffer} Ranges are
+similar to buffers in that there is no specific syntax to create them,
+but they are created using the \function{xrange()}
+function.\bifuncindex{xrange}
\indexii{sequence}{types}
\indexii{string}{type}
\indexii{Unicode}{type}
@@ -630,10 +633,27 @@ In this case no \code{*} specifiers may occur in a format (since they
require a sequential parameter list).
Additional string operations are defined in standard module
-\module{string} and in built-in module \module{re}.
+\refmodule{string} and in built-in module \refmodule{re}.
\refstmodindex{string}
\refstmodindex{re}
+
+\subsubsection{Range Type \label{typesseq-range}}
+
+The range\indexii{range}{type} type is an immutable sequence which is
+commonly used for looping. The advantage of the range type is that a
+range object will always take the same amount of memory, no matter the
+size of the range it represents. There are no consistent performance
+advantages.
+
+Range objects behave like tuples, and offer a single method:
+
+\begin{methoddesc}[range]{tolist}{}
+ Return a list object which represents the same values as the range
+ object.
+\end{methoddesc}
+
+
\subsubsection{Mutable Sequence Types \label{typesseq-mutable}}
List objects support additional operations that allow in-place