blob: bbbd90bc808a61cfd55721351c347afe16bcf787 [file] [log] [blame]
Fred Drake295da241998-08-10 19:42:37 +00001\section{\module{array} ---
Fred Drake4f6e4fb1999-04-21 16:38:53 +00002 Efficient arrays of numeric values}
Fred Drakeb91e9341998-07-23 17:59:49 +00003
Fred Drake4f6e4fb1999-04-21 16:38:53 +00004\declaremodule{builtin}{array}
Fred Drakeb91e9341998-07-23 17:59:49 +00005\modulesynopsis{Efficient arrays of uniformly typed numeric values.}
6
Guido van Rossum5fdeeea1994-01-02 01:22:07 +00007
8This module defines a new object type which can efficiently represent
9an array of basic values: characters, integers, floating point
Fred Drake4f6e4fb1999-04-21 16:38:53 +000010numbers. Arrays\index{arrays} are sequence types and behave very much
11like lists, except that the type of objects stored in them is
12constrained. The type is specified at object creation time by using a
13\dfn{type code}, which is a single character. The following type
14codes are defined:
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000015
Fred Drakeee601911998-04-11 20:53:03 +000016\begin{tableiii}{c|l|c}{code}{Type code}{C Type}{Minimum size in bytes}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000017\lineiii{'c'}{character}{1}
Fred Drakee9e05961998-12-10 05:04:21 +000018\lineiii{'b'}{signed int}{1}
19\lineiii{'B'}{unsigned int}{1}
20\lineiii{'h'}{signed int}{2}
21\lineiii{'H'}{unsigned int}{2}
22\lineiii{'i'}{signed int}{2}
23\lineiii{'I'}{unsigned int}{2}
24\lineiii{'l'}{signed int}{4}
25\lineiii{'L'}{unsigned int}{4}
26\lineiii{'f'}{float}{4}
27\lineiii{'d'}{double}{8}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000028\end{tableiii}
29
30The actual representation of values is determined by the machine
Fred Drake4f6e4fb1999-04-21 16:38:53 +000031architecture (strictly speaking, by the C implementation). The actual
Fred Drakee9e05961998-12-10 05:04:21 +000032size can be accessed through the \member{itemsize} attribute. The values
Guido van Rossumb0b81811997-01-03 19:20:52 +000033stored for \code{'L'} and \code{'I'} items will be represented as
34Python long integers when retrieved, because Python's plain integer
Fred Drake4f6e4fb1999-04-21 16:38:53 +000035type cannot represent the full range of C's unsigned (long) integers.
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000036
Guido van Rossumecde7811995-03-28 13:35:14 +000037
Fred Drakedd1f52b1998-04-03 03:35:24 +000038The module defines the following function and type object:
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000039
Fred Drakecce10901998-03-17 06:33:25 +000040\begin{funcdesc}{array}{typecode\optional{, initializer}}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000041Return a new array whose items are restricted by \var{typecode}, and
42initialized from the optional \var{initializer} value, which must be a
43list or a string. The list or string is passed to the new array's
Fred Drake8a135251998-02-27 15:19:42 +000044\method{fromlist()} or \method{fromstring()} method (see below) to add
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000045initial items to the array.
46\end{funcdesc}
47
Fred Drakedd1f52b1998-04-03 03:35:24 +000048\begin{datadesc}{ArrayType}
49Type object corresponding to the objects returned by
50\function{array()}.
51\end{datadesc}
52
53
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000054Array objects support the following data items and methods:
55
Fred Drakedd1f52b1998-04-03 03:35:24 +000056\begin{memberdesc}[array]{typecode}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000057The typecode character used to create the array.
Fred Drakedd1f52b1998-04-03 03:35:24 +000058\end{memberdesc}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000059
Fred Drakedd1f52b1998-04-03 03:35:24 +000060\begin{memberdesc}[array]{itemsize}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000061The length in bytes of one array item in the internal representation.
Fred Drakedd1f52b1998-04-03 03:35:24 +000062\end{memberdesc}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000063
Fred Drake8a135251998-02-27 15:19:42 +000064
Fred Drakedd1f52b1998-04-03 03:35:24 +000065\begin{methoddesc}[array]{append}{x}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000066Append a new item with value \var{x} to the end of the array.
Fred Drakedd1f52b1998-04-03 03:35:24 +000067\end{methoddesc}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000068
Fred Drakedd1f52b1998-04-03 03:35:24 +000069\begin{methoddesc}[array]{buffer_info}{}
Fred Drakebef9b0b1997-12-29 19:33:45 +000070Return a tuple \code{(\var{address}, \var{length})} giving the current
Guido van Rossum8f062471997-08-14 19:50:37 +000071memory address and the length in bytes of the buffer used to hold
72array's contents. This is occasionally useful when working with
73low-level (and inherently unsafe) I/O interfaces that require memory
Fred Drake8a135251998-02-27 15:19:42 +000074addresses, such as certain \cfunction{ioctl()} operations. The returned
Guido van Rossum8f062471997-08-14 19:50:37 +000075numbers are valid as long as the array exists and no length-changing
76operations are applied to it.
Fred Drakedd1f52b1998-04-03 03:35:24 +000077\end{methoddesc}
Guido van Rossum8f062471997-08-14 19:50:37 +000078
Fred Drake38e5d272000-04-03 20:13:55 +000079\begin{methoddesc}[array]{byteswap}{}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000080``Byteswap'' all items of the array. This is only supported for
Fred Drake38e5d272000-04-03 20:13:55 +000081values which are 1, 2, 4, or 8 bytes in size; for other types of
82values, \exception{RuntimeError} is raised. It is useful when reading
83data from a file written on a machine with a different byte order.
Fred Drakedd1f52b1998-04-03 03:35:24 +000084\end{methoddesc}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000085
Peter Schneider-Kamp5a65c2d2000-07-31 20:52:21 +000086\begin{methoddesc}[array]{count}{x}
87Return the number of occurences of \var{x} in the array.
88\end{methoddesc}
89
90\begin{methoddesc}[array]{extend}{a}
91Append array items from \var{a} to the end of the array.
92\end{methoddesc}
93
Fred Drakedd1f52b1998-04-03 03:35:24 +000094\begin{methoddesc}[array]{fromfile}{f, n}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000095Read \var{n} items (as machine values) from the file object \var{f}
96and append them to the end of the array. If less than \var{n} items
Fred Drake8a135251998-02-27 15:19:42 +000097are available, \exception{EOFError} is raised, but the items that were
Guido van Rossum470be141995-03-17 16:07:09 +000098available are still inserted into the array. \var{f} must be a real
Fred Drakedd1f52b1998-04-03 03:35:24 +000099built-in file object; something else with a \method{read()} method won't
Guido van Rossum470be141995-03-17 16:07:09 +0000100do.
Fred Drakedd1f52b1998-04-03 03:35:24 +0000101\end{methoddesc}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000102
Fred Drakedd1f52b1998-04-03 03:35:24 +0000103\begin{methoddesc}[array]{fromlist}{list}
Guido van Rossum6c4f0031995-03-07 10:14:09 +0000104Append items from the list. This is equivalent to
Fred Drake8a135251998-02-27 15:19:42 +0000105\samp{for x in \var{list}:\ a.append(x)}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000106except that if there is a type error, the array is unchanged.
Fred Drakedd1f52b1998-04-03 03:35:24 +0000107\end{methoddesc}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000108
Fred Drakedd1f52b1998-04-03 03:35:24 +0000109\begin{methoddesc}[array]{fromstring}{s}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000110Appends items from the string, interpreting the string as an
Fred Drake91f2f262001-07-06 19:28:48 +0000111array of machine values (as if it had been read from a
Fred Drake8a135251998-02-27 15:19:42 +0000112file using the \method{fromfile()} method).
Fred Drakedd1f52b1998-04-03 03:35:24 +0000113\end{methoddesc}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000114
Peter Schneider-Kamp5a65c2d2000-07-31 20:52:21 +0000115\begin{methoddesc}[array]{index}{x}
116Return the smallest \var{i} such that \var{i} is the index of
117the first occurence of \var{x} in the array.
118\end{methoddesc}
119
Fred Drakedd1f52b1998-04-03 03:35:24 +0000120\begin{methoddesc}[array]{insert}{i, x}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000121Insert a new item with value \var{x} in the array before position
122\var{i}.
Fred Drakedd1f52b1998-04-03 03:35:24 +0000123\end{methoddesc}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000124
Peter Schneider-Kamp5a65c2d2000-07-31 20:52:21 +0000125\begin{methoddesc}[array]{pop}{\optional{i}}
126Removes the item with the index \var{i} from the array and returns
127it. The optional argument defaults to \code{-1}, so that by default
128the last item is removed and returned.
129\end{methoddesc}
130
Fred Drakedd1f52b1998-04-03 03:35:24 +0000131\begin{methoddesc}[array]{read}{f, n}
Fred Drake92e31941998-02-27 16:21:31 +0000132\deprecated {1.5.1}
133 {Use the \method{fromfile()} method.}
Fred Drake8a135251998-02-27 15:19:42 +0000134Read \var{n} items (as machine values) from the file object \var{f}
135and append them to the end of the array. If less than \var{n} items
136are available, \exception{EOFError} is raised, but the items that were
137available are still inserted into the array. \var{f} must be a real
138built-in file object; something else with a \method{read()} method won't
139do.
Fred Drakedd1f52b1998-04-03 03:35:24 +0000140\end{methoddesc}
Fred Drake8a135251998-02-27 15:19:42 +0000141
Peter Schneider-Kamp5a65c2d2000-07-31 20:52:21 +0000142\begin{methoddesc}[array]{remove}{x}
143Remove the first occurence of \var{x} from the array.
144\end{methoddesc}
145
Fred Drakedd1f52b1998-04-03 03:35:24 +0000146\begin{methoddesc}[array]{reverse}{}
Fred Drake8a135251998-02-27 15:19:42 +0000147Reverse the order of the items in the array.
Fred Drakedd1f52b1998-04-03 03:35:24 +0000148\end{methoddesc}
Fred Drake8a135251998-02-27 15:19:42 +0000149
Fred Drakedd1f52b1998-04-03 03:35:24 +0000150\begin{methoddesc}[array]{tofile}{f}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000151Write all items (as machine values) to the file object \var{f}.
Fred Drakedd1f52b1998-04-03 03:35:24 +0000152\end{methoddesc}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000153
Fred Drakedd1f52b1998-04-03 03:35:24 +0000154\begin{methoddesc}[array]{tolist}{}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000155Convert the array to an ordinary list with the same items.
Fred Drakedd1f52b1998-04-03 03:35:24 +0000156\end{methoddesc}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000157
Fred Drakedd1f52b1998-04-03 03:35:24 +0000158\begin{methoddesc}[array]{tostring}{}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000159Convert the array to an array of machine values and return the
160string representation (the same sequence of bytes that would
Fred Drake8a135251998-02-27 15:19:42 +0000161be written to a file by the \method{tofile()} method.)
Fred Drakedd1f52b1998-04-03 03:35:24 +0000162\end{methoddesc}
Fred Drake8a135251998-02-27 15:19:42 +0000163
Fred Drakedd1f52b1998-04-03 03:35:24 +0000164\begin{methoddesc}[array]{write}{f}
Fred Drake92e31941998-02-27 16:21:31 +0000165\deprecated {1.5.1}
166 {Use the \method{tofile()} method.}
Fred Drake8a135251998-02-27 15:19:42 +0000167Write all items (as machine values) to the file object \var{f}.
Fred Drakedd1f52b1998-04-03 03:35:24 +0000168\end{methoddesc}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000169
170When an array object is printed or converted to a string, it is
171represented as \code{array(\var{typecode}, \var{initializer})}. The
172\var{initializer} is omitted if the array is empty, otherwise it is a
173string if the \var{typecode} is \code{'c'}, otherwise it is a list of
174numbers. The string is guaranteed to be able to be converted back to
175an array with the same type and value using reverse quotes
Fred Drake38e5d272000-04-03 20:13:55 +0000176(\code{``}), so long as the \function{array()} function has been
177imported using \samp{from array import array}. Examples:
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000178
Fred Drake19479911998-02-13 06:58:54 +0000179\begin{verbatim}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +0000180array('l')
181array('c', 'hello world')
182array('l', [1, 2, 3, 4, 5])
183array('d', [1.0, 2.0, 3.14])
Fred Drake19479911998-02-13 06:58:54 +0000184\end{verbatim}
Fred Drakedd1f52b1998-04-03 03:35:24 +0000185
186
187\begin{seealso}
Fred Drakeba0a9892000-10-18 17:43:06 +0000188 \seemodule{struct}{Packing and unpacking of heterogeneous binary data.}
189 \seemodule{xdrlib}{Packing and unpacking of External Data
190 Representation (XDR) data as used in some remote
191 procedure call systems.}
Fred Drakeed911b82000-12-11 20:57:13 +0000192 \seetitle[http://numpy.sourceforge.net/numdoc/HTML/numdoc.html]{The
Fred Drakeb4b401e2000-10-17 04:58:01 +0000193 Numerical Python Manual}{The Numeric Python extension
194 (NumPy) defines another array type; see
195 \url{http://numpy.sourceforge.net/} for further information
Fred Drakeed911b82000-12-11 20:57:13 +0000196 about Numerical Python. (A PDF version of the NumPy manual
197 is available at
198 \url{http://numpy.sourceforge.net/numdoc/numdoc.pdf}.}
Fred Drakedd1f52b1998-04-03 03:35:24 +0000199\end{seealso}