| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | :mod:`array` --- Efficient arrays of numeric values
 | 
					
						
							|  |  |  | ===================================================
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. module:: array
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 62021,62029,62035-62038,62043-62044,62052-62053 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r62021 | benjamin.peterson | 2008-03-28 18:11:01 -0500 (Fri, 28 Mar 2008) | 2 lines
  NIL => NULL
........
  r62029 | amaury.forgeotdarc | 2008-03-28 20:42:31 -0500 (Fri, 28 Mar 2008) | 3 lines
  Correctly call the base class tearDown();
  otherwise running test_logging twice produce the errors we see on all buildbots
........
  r62035 | raymond.hettinger | 2008-03-29 05:42:07 -0500 (Sat, 29 Mar 2008) | 1 line
  Be explicit about what efficient means.
........
  r62036 | georg.brandl | 2008-03-29 06:46:18 -0500 (Sat, 29 Mar 2008) | 2 lines
  Fix capitalization.
........
  r62037 | amaury.forgeotdarc | 2008-03-29 07:42:54 -0500 (Sat, 29 Mar 2008) | 5 lines
  lib2to3 should install a logging handler only when run as a main program,
  not when used as a library.
  This may please the buildbots, which fail when test_lib2to3 is run before test_logging.
........
  r62043 | benjamin.peterson | 2008-03-29 10:24:25 -0500 (Sat, 29 Mar 2008) | 3 lines
  #2503 make singletons compared with "is" not == or !=
  Thanks to Wummel for the patch
........
  r62044 | gerhard.haering | 2008-03-29 14:11:52 -0500 (Sat, 29 Mar 2008) | 2 lines
  Documented the lastrowid attribute.
........
  r62052 | benjamin.peterson | 2008-03-30 14:35:10 -0500 (Sun, 30 Mar 2008) | 2 lines
  Updated README regarding doc formats
........
  r62053 | georg.brandl | 2008-03-30 14:41:39 -0500 (Sun, 30 Mar 2008) | 2 lines
  The other download formats will be available for 2.6 too.
........
											
										 
											2008-03-31 01:51:45 +00:00
										 |  |  |    :synopsis: Space efficient arrays of uniformly typed numeric values.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. index:: single: arrays
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-11 15:02:54 -04:00
										 |  |  | --------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 62021,62029,62035-62038,62043-62044,62052-62053 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r62021 | benjamin.peterson | 2008-03-28 18:11:01 -0500 (Fri, 28 Mar 2008) | 2 lines
  NIL => NULL
........
  r62029 | amaury.forgeotdarc | 2008-03-28 20:42:31 -0500 (Fri, 28 Mar 2008) | 3 lines
  Correctly call the base class tearDown();
  otherwise running test_logging twice produce the errors we see on all buildbots
........
  r62035 | raymond.hettinger | 2008-03-29 05:42:07 -0500 (Sat, 29 Mar 2008) | 1 line
  Be explicit about what efficient means.
........
  r62036 | georg.brandl | 2008-03-29 06:46:18 -0500 (Sat, 29 Mar 2008) | 2 lines
  Fix capitalization.
........
  r62037 | amaury.forgeotdarc | 2008-03-29 07:42:54 -0500 (Sat, 29 Mar 2008) | 5 lines
  lib2to3 should install a logging handler only when run as a main program,
  not when used as a library.
  This may please the buildbots, which fail when test_lib2to3 is run before test_logging.
........
  r62043 | benjamin.peterson | 2008-03-29 10:24:25 -0500 (Sat, 29 Mar 2008) | 3 lines
  #2503 make singletons compared with "is" not == or !=
  Thanks to Wummel for the patch
........
  r62044 | gerhard.haering | 2008-03-29 14:11:52 -0500 (Sat, 29 Mar 2008) | 2 lines
  Documented the lastrowid attribute.
........
  r62052 | benjamin.peterson | 2008-03-30 14:35:10 -0500 (Sun, 30 Mar 2008) | 2 lines
  Updated README regarding doc formats
........
  r62053 | georg.brandl | 2008-03-30 14:41:39 -0500 (Sun, 30 Mar 2008) | 2 lines
  The other download formats will be available for 2.6 too.
........
											
										 
											2008-03-31 01:51:45 +00:00
										 |  |  | This module defines an object type which can compactly represent an array of
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | basic values: characters, integers, floating point numbers.  Arrays are sequence
 | 
					
						
							|  |  |  | types and behave very much like lists, except that the type of objects stored in
 | 
					
						
							|  |  |  | them is constrained.  The type is specified at object creation time by using a
 | 
					
						
							|  |  |  | :dfn:`type code`, which is a single character.  The following type codes are
 | 
					
						
							|  |  |  | defined:
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-20 19:55:51 -05:00
										 |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							|  |  |  | | Type code | C Type             | Python Type       | Minimum size in bytes | Notes |
 | 
					
						
							|  |  |  | +===========+====================+===================+=======================+=======+
 | 
					
						
							|  |  |  | | ``'b'``   | signed char        | int               | 1                     |       |
 | 
					
						
							|  |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							|  |  |  | | ``'B'``   | unsigned char      | int               | 1                     |       |
 | 
					
						
							|  |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							| 
									
										
										
										
											2020-05-11 15:37:25 +09:00
										 |  |  | | ``'u'``   | wchar_t            | Unicode character | 2                     | \(1)  |
 | 
					
						
							| 
									
										
										
										
											2011-09-20 19:55:51 -05:00
										 |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							| 
									
										
										
										
											2023-06-05 01:45:00 +09:00
										 |  |  | | ``'w'``   | Py_UCS4            | Unicode character | 4                     |       |
 | 
					
						
							|  |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							| 
									
										
										
										
											2011-09-20 19:55:51 -05:00
										 |  |  | | ``'h'``   | signed short       | int               | 2                     |       |
 | 
					
						
							|  |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							|  |  |  | | ``'H'``   | unsigned short     | int               | 2                     |       |
 | 
					
						
							|  |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							|  |  |  | | ``'i'``   | signed int         | int               | 2                     |       |
 | 
					
						
							|  |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							|  |  |  | | ``'I'``   | unsigned int       | int               | 2                     |       |
 | 
					
						
							|  |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							|  |  |  | | ``'l'``   | signed long        | int               | 4                     |       |
 | 
					
						
							|  |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							|  |  |  | | ``'L'``   | unsigned long      | int               | 4                     |       |
 | 
					
						
							|  |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							| 
									
										
										
										
											2019-08-22 20:28:28 +05:00
										 |  |  | | ``'q'``   | signed long long   | int               | 8                     |       |
 | 
					
						
							| 
									
										
										
										
											2011-09-20 19:55:51 -05:00
										 |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							| 
									
										
										
										
											2019-08-22 20:28:28 +05:00
										 |  |  | | ``'Q'``   | unsigned long long | int               | 8                     |       |
 | 
					
						
							| 
									
										
										
										
											2011-09-20 19:55:51 -05:00
										 |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							|  |  |  | | ``'f'``   | float              | float             | 4                     |       |
 | 
					
						
							|  |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							|  |  |  | | ``'d'``   | double             | float             | 8                     |       |
 | 
					
						
							|  |  |  | +-----------+--------------------+-------------------+-----------------------+-------+
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Notes:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (1)
 | 
					
						
							| 
									
										
										
										
											2020-05-11 15:37:25 +09:00
										 |  |  |    It can be 16 bits or 32 bits depending on the platform.
 | 
					
						
							| 
									
										
										
										
											2012-08-06 00:46:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-11 15:37:25 +09:00
										 |  |  |    .. versionchanged:: 3.9
 | 
					
						
							| 
									
										
										
										
											2023-07-22 21:35:22 +03:00
										 |  |  |       ``array('u')`` now uses :c:type:`wchar_t` as C type instead of deprecated
 | 
					
						
							| 
									
										
										
										
											2022-06-01 00:52:03 +03:00
										 |  |  |       ``Py_UNICODE``. This change doesn't affect its behavior because
 | 
					
						
							| 
									
										
										
										
											2023-07-22 21:35:22 +03:00
										 |  |  |       ``Py_UNICODE`` is alias of :c:type:`wchar_t` since Python 3.3.
 | 
					
						
							| 
									
										
										
										
											2012-08-24 20:14:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-11 12:17:35 +03:00
										 |  |  |    .. deprecated-removed:: 3.3 3.16
 | 
					
						
							| 
									
										
										
										
											2023-06-05 01:45:00 +09:00
										 |  |  |       Please migrate to ``'w'`` typecode.
 | 
					
						
							| 
									
										
										
										
											2012-08-24 20:14:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-11 15:37:25 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | The actual representation of values is determined by the machine architecture
 | 
					
						
							|  |  |  | (strictly speaking, by the C implementation).  The actual size can be accessed
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  | through the :attr:`array.itemsize` attribute.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-28 13:26:01 +03:00
										 |  |  | The module defines the following item:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. data:: typecodes
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A string with all available type codes.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | The module defines the following type:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 73930-73932,73937-73939,73945,73951,73954,73962-73963,73970 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r73930 | amaury.forgeotdarc | 2009-07-10 12:47:42 -0400 (Fri, 10 Jul 2009) | 2 lines
  #6447: typo in subprocess docstring
........
  r73931 | ezio.melotti | 2009-07-10 16:25:56 -0400 (Fri, 10 Jul 2009) | 1 line
  more cleanups and if zlib -> skipUnless(zlib)
........
  r73932 | kristjan.jonsson | 2009-07-11 04:44:43 -0400 (Sat, 11 Jul 2009) | 3 lines
  http://bugs.python.org/issue6460
  Need to be careful with thread switching when testing the xmlrpc server.  The server thread may not have updated stats when the client thread tests them.
........
  r73937 | georg.brandl | 2009-07-11 06:12:36 -0400 (Sat, 11 Jul 2009) | 1 line
  Fix style.
........
  r73938 | georg.brandl | 2009-07-11 06:14:54 -0400 (Sat, 11 Jul 2009) | 1 line
  #6446: fix import_spam() function to use correct error and reference handling.
........
  r73939 | georg.brandl | 2009-07-11 06:18:10 -0400 (Sat, 11 Jul 2009) | 1 line
  #6448: clarify docs for find_module().
........
  r73945 | georg.brandl | 2009-07-11 06:51:31 -0400 (Sat, 11 Jul 2009) | 1 line
  #6456: clarify the meaning of constants used as arguments to nl_langinfo().
........
  r73951 | georg.brandl | 2009-07-11 10:23:38 -0400 (Sat, 11 Jul 2009) | 2 lines
  array.array is actually a class.
........
  r73954 | tarek.ziade | 2009-07-11 13:21:00 -0400 (Sat, 11 Jul 2009) | 1 line
  reverted changes for #6459 (doesn't apply on 2.x)
........
  r73962 | benjamin.peterson | 2009-07-11 18:15:13 -0400 (Sat, 11 Jul 2009) | 1 line
  put downloaded test support files in Lib/test/data instead of the cwd
........
  r73963 | benjamin.peterson | 2009-07-11 18:25:24 -0400 (Sat, 11 Jul 2009) | 1 line
  ignore things in Lib/test/data/
........
  r73970 | hirokazu.yamamoto | 2009-07-11 22:04:47 -0400 (Sat, 11 Jul 2009) | 1 line
  Fixed distutils test.
........
											
										 
											2009-07-17 10:42:05 +00:00
										 |  |  | .. class:: array(typecode[, initializer])
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 73930-73932,73937-73939,73945,73951,73954,73962-73963,73970 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r73930 | amaury.forgeotdarc | 2009-07-10 12:47:42 -0400 (Fri, 10 Jul 2009) | 2 lines
  #6447: typo in subprocess docstring
........
  r73931 | ezio.melotti | 2009-07-10 16:25:56 -0400 (Fri, 10 Jul 2009) | 1 line
  more cleanups and if zlib -> skipUnless(zlib)
........
  r73932 | kristjan.jonsson | 2009-07-11 04:44:43 -0400 (Sat, 11 Jul 2009) | 3 lines
  http://bugs.python.org/issue6460
  Need to be careful with thread switching when testing the xmlrpc server.  The server thread may not have updated stats when the client thread tests them.
........
  r73937 | georg.brandl | 2009-07-11 06:12:36 -0400 (Sat, 11 Jul 2009) | 1 line
  Fix style.
........
  r73938 | georg.brandl | 2009-07-11 06:14:54 -0400 (Sat, 11 Jul 2009) | 1 line
  #6446: fix import_spam() function to use correct error and reference handling.
........
  r73939 | georg.brandl | 2009-07-11 06:18:10 -0400 (Sat, 11 Jul 2009) | 1 line
  #6448: clarify docs for find_module().
........
  r73945 | georg.brandl | 2009-07-11 06:51:31 -0400 (Sat, 11 Jul 2009) | 1 line
  #6456: clarify the meaning of constants used as arguments to nl_langinfo().
........
  r73951 | georg.brandl | 2009-07-11 10:23:38 -0400 (Sat, 11 Jul 2009) | 2 lines
  array.array is actually a class.
........
  r73954 | tarek.ziade | 2009-07-11 13:21:00 -0400 (Sat, 11 Jul 2009) | 1 line
  reverted changes for #6459 (doesn't apply on 2.x)
........
  r73962 | benjamin.peterson | 2009-07-11 18:15:13 -0400 (Sat, 11 Jul 2009) | 1 line
  put downloaded test support files in Lib/test/data instead of the cwd
........
  r73963 | benjamin.peterson | 2009-07-11 18:25:24 -0400 (Sat, 11 Jul 2009) | 1 line
  ignore things in Lib/test/data/
........
  r73970 | hirokazu.yamamoto | 2009-07-11 22:04:47 -0400 (Sat, 11 Jul 2009) | 1 line
  Fixed distutils test.
........
											
										 
											2009-07-17 10:42:05 +00:00
										 |  |  |    A new array whose items are restricted by *typecode*, and initialized
 | 
					
						
							| 
									
										
										
										
											2024-01-22 10:42:50 +02:00
										 |  |  |    from the optional *initializer* value, which must be a :class:`bytes`
 | 
					
						
							|  |  |  |    or :class:`bytearray` object, a Unicode string, or iterable over elements
 | 
					
						
							|  |  |  |    of the appropriate type.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-22 10:42:50 +02:00
										 |  |  |    If given a :class:`bytes` or :class:`bytearray` object, the initializer
 | 
					
						
							|  |  |  |    is passed to the new array's :meth:`frombytes` method;
 | 
					
						
							|  |  |  |    if given a Unicode string, the initializer is passed to the
 | 
					
						
							|  |  |  |    :meth:`fromunicode` method;
 | 
					
						
							|  |  |  |    otherwise, the initializer's iterator is passed to the :meth:`extend` method
 | 
					
						
							|  |  |  |    to add initial items to the array.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    Array objects support the ordinary sequence operations of indexing, slicing,
 | 
					
						
							|  |  |  |    concatenation, and multiplication.  When using slice assignment, the assigned
 | 
					
						
							|  |  |  |    value must be an array object with the same type code; in all other cases,
 | 
					
						
							|  |  |  |    :exc:`TypeError` is raised. Array objects also implement the buffer interface,
 | 
					
						
							|  |  |  |    and may be used wherever :term:`bytes-like objects <bytes-like object>` are supported.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. audit-event:: array.__new__ typecode,initializer array.array
 | 
					
						
							| 
									
										
										
										
											2007-11-06 21:34:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. attribute:: typecode
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       The typecode character used to create the array.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. attribute:: itemsize
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       The length in bytes of one array item in the internal representation.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: append(x)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       Append a new item with value *x* to the end of the array.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: buffer_info()
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       Return a tuple ``(address, length)`` giving the current memory address and the
 | 
					
						
							|  |  |  |       length in elements of the buffer used to hold array's contents.  The size of the
 | 
					
						
							|  |  |  |       memory buffer in bytes can be computed as ``array.buffer_info()[1] *
 | 
					
						
							|  |  |  |       array.itemsize``.  This is occasionally useful when working with low-level (and
 | 
					
						
							|  |  |  |       inherently unsafe) I/O interfaces that require memory addresses, such as certain
 | 
					
						
							|  |  |  |       :c:func:`!ioctl` operations.  The returned numbers are valid as long as the array
 | 
					
						
							|  |  |  |       exists and no length-changing operations are applied to it.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       .. note::
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |          When using array objects from code written in C or C++ (the only way to
 | 
					
						
							|  |  |  |          effectively make use of this information), it makes more sense to use the buffer
 | 
					
						
							|  |  |  |          interface supported by array objects.  This method is maintained for backward
 | 
					
						
							|  |  |  |          compatibility and should be avoided in new code.  The buffer interface is
 | 
					
						
							|  |  |  |          documented in :ref:`bufferobjects`.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: byteswap()
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       "Byteswap" all items of the array.  This is only supported for values which are
 | 
					
						
							|  |  |  |       1, 2, 4, or 8 bytes in size; for other types of values, :exc:`RuntimeError` is
 | 
					
						
							|  |  |  |       raised.  It is useful when reading data from a file written on a machine with a
 | 
					
						
							|  |  |  |       different byte order.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: count(x)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       Return the number of occurrences of *x* in the array.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: extend(iterable)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       Append items from *iterable* to the end of the array.  If *iterable* is another
 | 
					
						
							|  |  |  |       array, it must have *exactly* the same type code; if not, :exc:`TypeError` will
 | 
					
						
							|  |  |  |       be raised.  If *iterable* is not an array, it must be iterable and its elements
 | 
					
						
							|  |  |  |       must be the right type to be appended to the array.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-22 10:42:50 +02:00
										 |  |  |    .. method:: frombytes(buffer)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-22 10:42:50 +02:00
										 |  |  |       Appends items from the :term:`bytes-like object`, interpreting
 | 
					
						
							|  |  |  |       its content as an array of machine values (as if it had been read
 | 
					
						
							|  |  |  |       from a file using the :meth:`fromfile` method).
 | 
					
						
							| 
									
										
										
										
											2010-09-01 20:29:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       .. versionadded:: 3.2
 | 
					
						
							|  |  |  |          :meth:`!fromstring` is renamed to :meth:`frombytes` for clarity.
 | 
					
						
							| 
									
										
										
										
											2010-09-01 20:29:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: fromfile(f, n)
 | 
					
						
							| 
									
										
										
										
											2010-09-01 20:29:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       Read *n* items (as machine values) from the :term:`file object` *f* and append
 | 
					
						
							|  |  |  |       them to the end of the array.  If less than *n* items are available,
 | 
					
						
							|  |  |  |       :exc:`EOFError` is raised, but the items that were available are still
 | 
					
						
							|  |  |  |       inserted into the array.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: fromlist(list)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       Append items from the list.  This is equivalent to ``for x in list:
 | 
					
						
							|  |  |  |       a.append(x)`` except that if there is a type error, the array is unchanged.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: fromunicode(s)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-22 10:42:50 +02:00
										 |  |  |       Extends this array with data from the given Unicode string.
 | 
					
						
							| 
									
										
										
										
											2023-06-05 01:45:00 +09:00
										 |  |  |       The array must have type code ``'u'`` or ``'w'``; otherwise a :exc:`ValueError` is raised.
 | 
					
						
							|  |  |  |       Use ``array.frombytes(unicodestring.encode(enc))`` to append Unicode data to an
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       array of some other type.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: index(x[, start[, stop]])
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       Return the smallest *i* such that *i* is the index of the first occurrence of
 | 
					
						
							|  |  |  |       *x* in the array.  The optional arguments *start* and *stop* can be
 | 
					
						
							|  |  |  |       specified to search for *x* within a subsection of the array.  Raise
 | 
					
						
							|  |  |  |       :exc:`ValueError` if *x* is not found.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       .. versionchanged:: 3.10
 | 
					
						
							|  |  |  |          Added optional *start* and *stop* parameters.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: insert(i, x)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       Insert a new item with value *x* in the array before position *i*. Negative
 | 
					
						
							|  |  |  |       values are treated as being relative to the end of the array.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: pop([i])
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       Removes the item with the index *i* from the array and returns it. The optional
 | 
					
						
							|  |  |  |       argument defaults to ``-1``, so that by default the last item is removed and
 | 
					
						
							|  |  |  |       returned.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: remove(x)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       Remove the first occurrence of *x* from the array.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-10 19:59:46 +04:00
										 |  |  |    .. method:: clear()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       Remove all elements from the array.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       .. versionadded:: 3.13
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: reverse()
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       Reverse the order of the items in the array.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: tobytes()
 | 
					
						
							| 
									
										
										
										
											2010-09-01 20:29:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       Convert the array to an array of machine values and return the bytes
 | 
					
						
							|  |  |  |       representation (the same sequence of bytes that would be written to a file by
 | 
					
						
							|  |  |  |       the :meth:`tofile` method.)
 | 
					
						
							| 
									
										
										
										
											2010-09-01 20:29:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       .. versionadded:: 3.2
 | 
					
						
							|  |  |  |          :meth:`!tostring` is renamed to :meth:`tobytes` for clarity.
 | 
					
						
							| 
									
										
										
										
											2010-09-01 20:29:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: tofile(f)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       Write all items (as machine values) to the :term:`file object` *f*.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: tolist()
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       Convert the array to an ordinary list with the same items.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |    .. method:: tounicode()
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-22 10:42:50 +02:00
										 |  |  |       Convert the array to a Unicode string.  The array must have a type ``'u'`` or ``'w'``;
 | 
					
						
							| 
									
										
										
										
											2023-02-02 18:03:27 -06:00
										 |  |  |       otherwise a :exc:`ValueError` is raised. Use ``array.tobytes().decode(enc)`` to
 | 
					
						
							| 
									
										
										
										
											2024-01-22 10:42:50 +02:00
										 |  |  |       obtain a Unicode string from an array of some other type.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-22 10:42:50 +02:00
										 |  |  | The string representation of array objects has the form
 | 
					
						
							|  |  |  | ``array(typecode, initializer)``.
 | 
					
						
							|  |  |  | The *initializer* is omitted if the array is empty, otherwise it is
 | 
					
						
							|  |  |  | a Unicode string if the *typecode* is ``'u'`` or ``'w'``, otherwise it is
 | 
					
						
							|  |  |  | a list of numbers.
 | 
					
						
							|  |  |  | The string representation is guaranteed to be able to be converted back to an
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | array with the same type and value using :func:`eval`, so long as the
 | 
					
						
							| 
									
										
										
										
											2016-12-02 23:13:53 +02:00
										 |  |  | :class:`~array.array` class has been imported using ``from array import array``.
 | 
					
						
							| 
									
										
										
										
											2024-01-22 10:42:50 +02:00
										 |  |  | Variables ``inf`` and ``nan`` must also be defined if it contains
 | 
					
						
							|  |  |  | corresponding floating point values.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | Examples::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    array('l')
 | 
					
						
							| 
									
										
										
										
											2023-06-05 01:45:00 +09:00
										 |  |  |    array('w', 'hello \u2641')
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    array('l', [1, 2, 3, 4, 5])
 | 
					
						
							| 
									
										
										
										
											2024-01-22 10:42:50 +02:00
										 |  |  |    array('d', [1.0, 2.0, 3.14, -inf, nan])
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. seealso::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Module :mod:`struct`
 | 
					
						
							|  |  |  |       Packing and unpacking of heterogeneous binary data.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-01 20:22:14 -03:00
										 |  |  |    `NumPy <https://numpy.org/>`_
 | 
					
						
							|  |  |  |       The NumPy package defines another array type.
 |