| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | .. _tut-brieftourtwo:
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-04 15:42:13 +02:00
										 |  |  | **********************************************
 | 
					
						
							| 
									
										
										
										
											2016-12-04 10:20:55 +02:00
										 |  |  | Brief Tour of the Standard Library --- Part II
 | 
					
						
							|  |  |  | **********************************************
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | This second tour covers more advanced modules that support professional
 | 
					
						
							|  |  |  | programming needs.  These modules rarely occur in small scripts.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. _tut-output-formatting:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Output Formatting
 | 
					
						
							|  |  |  | =================
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-16 07:12:44 +00:00
										 |  |  | The :mod:`reprlib` module provides a version of :func:`repr` customized for
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | abbreviated displays of large or deeply nested containers::
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-16 07:12:44 +00:00
										 |  |  |    >>> import reprlib
 | 
					
						
							|  |  |  |    >>> reprlib.repr(set('supercalifragilisticexpialidocious'))
 | 
					
						
							| 
									
										
										
										
											2014-11-09 22:30:36 -08:00
										 |  |  |    "{'a', 'c', 'd', 'e', 'f', 'g', ...}"
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | The :mod:`pprint` module offers more sophisticated control over printing both
 | 
					
						
							|  |  |  | built-in and user defined objects in a way that is readable by the interpreter.
 | 
					
						
							|  |  |  | When the result is longer than one line, the "pretty printer" adds line breaks
 | 
					
						
							|  |  |  | and indentation to more clearly reveal data structure::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    >>> import pprint
 | 
					
						
							|  |  |  |    >>> t = [[[['black', 'cyan'], 'white', ['green', 'red']], [['magenta',
 | 
					
						
							|  |  |  |    ...     'yellow'], 'blue']]]
 | 
					
						
							|  |  |  |    ...
 | 
					
						
							|  |  |  |    >>> pprint.pprint(t, width=30)
 | 
					
						
							|  |  |  |    [[[['black', 'cyan'],
 | 
					
						
							|  |  |  |       'white',
 | 
					
						
							|  |  |  |       ['green', 'red']],
 | 
					
						
							|  |  |  |      [['magenta', 'yellow'],
 | 
					
						
							|  |  |  |       'blue']]]
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The :mod:`textwrap` module formats paragraphs of text to fit a given screen
 | 
					
						
							|  |  |  | width::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    >>> import textwrap
 | 
					
						
							|  |  |  |    >>> doc = """The wrap() method is just like fill() except that it returns
 | 
					
						
							|  |  |  |    ... a list of strings instead of one big string with newlines to separate
 | 
					
						
							|  |  |  |    ... the wrapped lines."""
 | 
					
						
							|  |  |  |    ...
 | 
					
						
							| 
									
										
										
										
											2007-09-04 07:15:32 +00:00
										 |  |  |    >>> print(textwrap.fill(doc, width=40))
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    The wrap() method is just like fill()
 | 
					
						
							|  |  |  |    except that it returns a list of strings
 | 
					
						
							|  |  |  |    instead of one big string with newlines
 | 
					
						
							|  |  |  |    to separate the wrapped lines.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The :mod:`locale` module accesses a database of culture specific data formats.
 | 
					
						
							|  |  |  | The grouping attribute of locale's format function provides a direct way of
 | 
					
						
							|  |  |  | formatting numbers with group separators::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    >>> import locale
 | 
					
						
							|  |  |  |    >>> locale.setlocale(locale.LC_ALL, 'English_United States.1252')
 | 
					
						
							|  |  |  |    'English_United States.1252'
 | 
					
						
							|  |  |  |    >>> conv = locale.localeconv()          # get a mapping of conventions
 | 
					
						
							|  |  |  |    >>> x = 1234567.8
 | 
					
						
							|  |  |  |    >>> locale.format("%d", x, grouping=True)
 | 
					
						
							|  |  |  |    '1,234,567'
 | 
					
						
							| 
									
										
										
										
											2009-08-13 12:06:43 +00:00
										 |  |  |    >>> locale.format_string("%s%.*f", (conv['currency_symbol'],
 | 
					
						
							|  |  |  |    ...                      conv['frac_digits'], x), grouping=True)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    '$1,234,567.80'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. _tut-templating:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Templating
 | 
					
						
							|  |  |  | ==========
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-09 09:54:46 +03:00
										 |  |  | The :mod:`string` module includes a versatile :class:`~string.Template` class
 | 
					
						
							|  |  |  | with a simplified syntax suitable for editing by end-users.  This allows users
 | 
					
						
							|  |  |  | to customize their applications without having to alter the application.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | The format uses placeholder names formed by ``$`` with valid Python identifiers
 | 
					
						
							|  |  |  | (alphanumeric characters and underscores).  Surrounding the placeholder with
 | 
					
						
							|  |  |  | braces allows it to be followed by more alphanumeric letters with no intervening
 | 
					
						
							|  |  |  | spaces.  Writing ``$$`` creates a single escaped ``$``::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    >>> from string import Template
 | 
					
						
							|  |  |  |    >>> t = Template('${village}folk send $$10 to $cause.')
 | 
					
						
							|  |  |  |    >>> t.substitute(village='Nottingham', cause='the ditch fund')
 | 
					
						
							|  |  |  |    'Nottinghamfolk send $10 to the ditch fund.'
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-09 09:54:46 +03:00
										 |  |  | The :meth:`~string.Template.substitute` method raises a :exc:`KeyError` when a
 | 
					
						
							|  |  |  | placeholder is not supplied in a dictionary or a keyword argument.  For
 | 
					
						
							|  |  |  | mail-merge style applications, user supplied data may be incomplete and the
 | 
					
						
							|  |  |  | :meth:`~string.Template.safe_substitute` method may be more appropriate ---
 | 
					
						
							|  |  |  | it will leave placeholders unchanged if data is missing::
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    >>> t = Template('Return the $item to $owner.')
 | 
					
						
							|  |  |  |    >>> d = dict(item='unladen swallow')
 | 
					
						
							|  |  |  |    >>> t.substitute(d)
 | 
					
						
							|  |  |  |    Traceback (most recent call last):
 | 
					
						
							| 
									
										
										
										
											2012-09-24 17:30:39 +03:00
										 |  |  |      ...
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    KeyError: 'owner'
 | 
					
						
							|  |  |  |    >>> t.safe_substitute(d)
 | 
					
						
							|  |  |  |    'Return the unladen swallow to $owner.'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Template subclasses can specify a custom delimiter.  For example, a batch
 | 
					
						
							|  |  |  | renaming utility for a photo browser may elect to use percent signs for
 | 
					
						
							|  |  |  | placeholders such as the current date, image sequence number, or file format::
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-02 22:48:17 +00:00
										 |  |  |    >>> import time, os.path
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    >>> photofiles = ['img_1074.jpg', 'img_1076.jpg', 'img_1077.jpg']
 | 
					
						
							|  |  |  |    >>> class BatchRename(Template):
 | 
					
						
							|  |  |  |    ...     delimiter = '%'
 | 
					
						
							| 
									
										
										
										
											2007-12-02 22:48:17 +00:00
										 |  |  |    >>> fmt = input('Enter rename style (%d-date %n-seqnum %f-format):  ')
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    Enter rename style (%d-date %n-seqnum %f-format):  Ashley_%n%f
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    >>> t = BatchRename(fmt)
 | 
					
						
							|  |  |  |    >>> date = time.strftime('%d%b%y')
 | 
					
						
							|  |  |  |    >>> for i, filename in enumerate(photofiles):
 | 
					
						
							|  |  |  |    ...     base, ext = os.path.splitext(filename)
 | 
					
						
							|  |  |  |    ...     newname = t.substitute(d=date, n=i, f=ext)
 | 
					
						
							| 
									
										
										
										
											2008-05-26 01:03:56 +00:00
										 |  |  |    ...     print('{0} --> {1}'.format(filename, newname))
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    img_1074.jpg --> Ashley_0.jpg
 | 
					
						
							|  |  |  |    img_1076.jpg --> Ashley_1.jpg
 | 
					
						
							|  |  |  |    img_1077.jpg --> Ashley_2.jpg
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Another application for templating is separating program logic from the details
 | 
					
						
							|  |  |  | of multiple output formats.  This makes it possible to substitute custom
 | 
					
						
							|  |  |  | templates for XML files, plain text reports, and HTML web reports.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. _tut-binary-formats:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Working with Binary Data Record Layouts
 | 
					
						
							|  |  |  | =======================================
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-09 09:54:46 +03:00
										 |  |  | The :mod:`struct` module provides :func:`~struct.pack` and
 | 
					
						
							|  |  |  | :func:`~struct.unpack` functions for working with variable length binary
 | 
					
						
							|  |  |  | record formats.  The following example shows
 | 
					
						
							| 
									
										
										
										
											2008-01-24 16:21:45 +00:00
										 |  |  | how to loop through header information in a ZIP file without using the
 | 
					
						
							|  |  |  | :mod:`zipfile` module.  Pack codes ``"H"`` and ``"I"`` represent two and four
 | 
					
						
							|  |  |  | byte unsigned numbers respectively.  The ``"<"`` indicates that they are
 | 
					
						
							|  |  |  | standard size and in little-endian byte order::
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    import struct
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-11 17:42:48 +01:00
										 |  |  |    with open('myfile.zip', 'rb') as f:
 | 
					
						
							|  |  |  |        data = f.read()
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    start = 0
 | 
					
						
							|  |  |  |    for i in range(3):                      # show the first 3 file headers
 | 
					
						
							|  |  |  |        start += 14
 | 
					
						
							| 
									
										
										
										
											2008-01-24 16:21:45 +00:00
										 |  |  |        fields = struct.unpack('<IIIHH', data[start:start+16])
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |        crc32, comp_size, uncomp_size, filenamesize, extra_size = fields
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        start += 16
 | 
					
						
							|  |  |  |        filename = data[start:start+filenamesize]
 | 
					
						
							|  |  |  |        start += filenamesize
 | 
					
						
							|  |  |  |        extra = data[start:start+extra_size]
 | 
					
						
							| 
									
										
										
										
											2007-09-04 07:15:32 +00:00
										 |  |  |        print(filename, hex(crc32), comp_size, uncomp_size)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |        start += extra_size + comp_size     # skip to the next header
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. _tut-multi-threading:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Multi-threading
 | 
					
						
							|  |  |  | ===============
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Threading is a technique for decoupling tasks which are not sequentially
 | 
					
						
							|  |  |  | dependent.  Threads can be used to improve the responsiveness of applications
 | 
					
						
							|  |  |  | that accept user input while other tasks run in the background.  A related use
 | 
					
						
							|  |  |  | case is running I/O in parallel with computations in another thread.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The following code shows how the high level :mod:`threading` module can run
 | 
					
						
							|  |  |  | tasks in background while the main program continues to run::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    import threading, zipfile
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    class AsyncZip(threading.Thread):
 | 
					
						
							|  |  |  |        def __init__(self, infile, outfile):
 | 
					
						
							| 
									
										
										
										
											2009-01-03 21:18:54 +00:00
										 |  |  |            threading.Thread.__init__(self)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |            self.infile = infile
 | 
					
						
							|  |  |  |            self.outfile = outfile
 | 
					
						
							| 
									
										
										
										
											2016-05-10 12:01:23 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |        def run(self):
 | 
					
						
							|  |  |  |            f = zipfile.ZipFile(self.outfile, 'w', zipfile.ZIP_DEFLATED)
 | 
					
						
							|  |  |  |            f.write(self.infile)
 | 
					
						
							|  |  |  |            f.close()
 | 
					
						
							| 
									
										
										
										
											2007-09-03 07:10:24 +00:00
										 |  |  |            print('Finished background zip of:', self.infile)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    background = AsyncZip('mydata.txt', 'myarchive.zip')
 | 
					
						
							|  |  |  |    background.start()
 | 
					
						
							| 
									
										
										
										
											2007-08-31 03:25:11 +00:00
										 |  |  |    print('The main program continues to run in foreground.')
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    background.join()    # Wait for the background task to finish
 | 
					
						
							| 
									
										
										
										
											2007-08-31 03:25:11 +00:00
										 |  |  |    print('Main program waited until background was done.')
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | The principal challenge of multi-threaded applications is coordinating threads
 | 
					
						
							|  |  |  | that share data or other resources.  To that end, the threading module provides
 | 
					
						
							|  |  |  | a number of synchronization primitives including locks, events, condition
 | 
					
						
							|  |  |  | variables, and semaphores.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | While those tools are powerful, minor design errors can result in problems that
 | 
					
						
							|  |  |  | are difficult to reproduce.  So, the preferred approach to task coordination is
 | 
					
						
							|  |  |  | to concentrate all access to a resource in a single thread and then use the
 | 
					
						
							| 
									
										
										
										
											2008-05-11 19:59:59 +00:00
										 |  |  | :mod:`queue` module to feed that thread with requests from other threads.
 | 
					
						
							| 
									
										
										
										
											2013-10-09 09:54:46 +03:00
										 |  |  | Applications using :class:`~queue.Queue` objects for inter-thread communication and
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | coordination are easier to design, more readable, and more reliable.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. _tut-logging:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Logging
 | 
					
						
							|  |  |  | =======
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The :mod:`logging` module offers a full featured and flexible logging system.
 | 
					
						
							|  |  |  | At its simplest, log messages are sent to a file or to ``sys.stderr``::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    import logging
 | 
					
						
							|  |  |  |    logging.debug('Debugging information')
 | 
					
						
							|  |  |  |    logging.info('Informational message')
 | 
					
						
							|  |  |  |    logging.warning('Warning:config file %s not found', 'server.conf')
 | 
					
						
							|  |  |  |    logging.error('Error occurred')
 | 
					
						
							|  |  |  |    logging.critical('Critical error -- shutting down')
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-24 17:30:39 +03:00
										 |  |  | This produces the following output:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: none
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    WARNING:root:Warning:config file server.conf not found
 | 
					
						
							|  |  |  |    ERROR:root:Error occurred
 | 
					
						
							|  |  |  |    CRITICAL:root:Critical error -- shutting down
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | By default, informational and debugging messages are suppressed and the output
 | 
					
						
							|  |  |  | is sent to standard error.  Other output options include routing messages
 | 
					
						
							|  |  |  | through email, datagrams, sockets, or to an HTTP Server.  New filters can select
 | 
					
						
							| 
									
										
										
										
											2013-10-09 09:54:46 +03:00
										 |  |  | different routing based on message priority: :const:`~logging.DEBUG`,
 | 
					
						
							|  |  |  | :const:`~logging.INFO`, :const:`~logging.WARNING`, :const:`~logging.ERROR`,
 | 
					
						
							|  |  |  | and :const:`~logging.CRITICAL`.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | The logging system can be configured directly from Python or can be loaded from
 | 
					
						
							|  |  |  | a user editable configuration file for customized logging without altering the
 | 
					
						
							|  |  |  | application.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. _tut-weak-references:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Weak References
 | 
					
						
							|  |  |  | ===============
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Python does automatic memory management (reference counting for most objects and
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 59259-59274 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r59260 | lars.gustaebel | 2007-12-01 22:02:12 +0100 (Sat, 01 Dec 2007) | 5 lines
  Issue #1531: Read fileobj from the current offset, do not seek to
  the start.
  (will backport to 2.5)
........
  r59262 | georg.brandl | 2007-12-01 23:24:47 +0100 (Sat, 01 Dec 2007) | 4 lines
  Document PyEval_* functions from ceval.c.
  Credits to Michael Sloan from GHOP.
........
  r59263 | georg.brandl | 2007-12-01 23:27:56 +0100 (Sat, 01 Dec 2007) | 2 lines
  Add a few refcount data entries.
........
  r59264 | georg.brandl | 2007-12-01 23:38:48 +0100 (Sat, 01 Dec 2007) | 4 lines
  Add test suite for cmd module.
  Written by Michael Schneider for GHOP.
........
  r59265 | georg.brandl | 2007-12-01 23:42:46 +0100 (Sat, 01 Dec 2007) | 3 lines
  Add examples to the ElementTree documentation.
  Written by h4wk.cz for GHOP.
........
  r59266 | georg.brandl | 2007-12-02 00:12:45 +0100 (Sun, 02 Dec 2007) | 3 lines
  Add "Using Python on Windows" document, by Robert Lehmann.
  Written for GHOP.
........
  r59271 | georg.brandl | 2007-12-02 15:34:34 +0100 (Sun, 02 Dec 2007) | 3 lines
  Add example to mmap docs.
  Written for GHOP by Rafal Rawicki.
........
  r59272 | georg.brandl | 2007-12-02 15:37:29 +0100 (Sun, 02 Dec 2007) | 2 lines
  Convert bdb.rst line endings to Unix style.
........
  r59274 | georg.brandl | 2007-12-02 15:58:50 +0100 (Sun, 02 Dec 2007) | 4 lines
  Add more entries to the glossary.
  Written by Jeff Wheeler for GHOP.
........
											
										 
											2007-12-02 15:22:16 +00:00
										 |  |  | :term:`garbage collection` to eliminate cycles).  The memory is freed shortly
 | 
					
						
							|  |  |  | after the last reference to it has been eliminated.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | This approach works fine for most applications but occasionally there is a need
 | 
					
						
							|  |  |  | to track objects only as long as they are being used by something else.
 | 
					
						
							|  |  |  | Unfortunately, just tracking them creates a reference that makes them permanent.
 | 
					
						
							|  |  |  | The :mod:`weakref` module provides tools for tracking objects without creating a
 | 
					
						
							|  |  |  | reference.  When the object is no longer needed, it is automatically removed
 | 
					
						
							|  |  |  | from a weakref table and a callback is triggered for weakref objects.  Typical
 | 
					
						
							|  |  |  | applications include caching objects that are expensive to create::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    >>> import weakref, gc
 | 
					
						
							|  |  |  |    >>> class A:
 | 
					
						
							|  |  |  |    ...     def __init__(self, value):
 | 
					
						
							| 
									
										
										
										
											2012-10-22 13:15:17 +02:00
										 |  |  |    ...         self.value = value
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    ...     def __repr__(self):
 | 
					
						
							| 
									
										
										
										
											2012-10-22 13:15:17 +02:00
										 |  |  |    ...         return str(self.value)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    ...
 | 
					
						
							|  |  |  |    >>> a = A(10)                   # create a reference
 | 
					
						
							|  |  |  |    >>> d = weakref.WeakValueDictionary()
 | 
					
						
							|  |  |  |    >>> d['primary'] = a            # does not create a reference
 | 
					
						
							|  |  |  |    >>> d['primary']                # fetch the object if it is still alive
 | 
					
						
							|  |  |  |    10
 | 
					
						
							|  |  |  |    >>> del a                       # remove the one reference
 | 
					
						
							|  |  |  |    >>> gc.collect()                # run garbage collection right away
 | 
					
						
							|  |  |  |    0
 | 
					
						
							|  |  |  |    >>> d['primary']                # entry was automatically removed
 | 
					
						
							|  |  |  |    Traceback (most recent call last):
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 60481,60485,60489-60492,60494-60496,60498-60499,60501-60503,60505-60506,60508-60509,60523-60524,60532,60543,60545,60547-60548,60552,60554,60556-60559,60561-60562,60569,60571-60572,60574,60576-60583,60585-60586,60589,60591,60594-60595,60597-60598,60600-60601,60606-60612,60615,60617,60619-60621,60623-60625,60627-60629,60631,60633,60635,60647,60650,60652,60654,60656,60658-60659,60664-60666,60668-60670,60672,60676,60678,60680-60683,60685-60686,60688,60690,60692-60694,60697-60700,60705-60706,60708,60711,60714,60720,60724-60730,60732,60736,60742,60744,60746,60748,60750-60751,60753,60756-60757,60759-60761,60763-60764,60766,60769-60770,60774-60784,60787-60789,60793,60796,60799-60809,60812-60813,60815-60821,60823-60826,60828-60829,60831-60834,60836,60838-60839,60846-60849,60852-60854,60856-60859,60861-60870,60874-60875,60880-60881,60886,60888-60890,60892,60894-60898,60900-60931,60933-60958 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r60901 | eric.smith | 2008-02-19 14:21:56 +0100 (Tue, 19 Feb 2008) | 1 line
  Added PEP 3101.
........
  r60907 | georg.brandl | 2008-02-20 20:12:36 +0100 (Wed, 20 Feb 2008) | 2 lines
  Fixes contributed by Ori Avtalion.
........
  r60909 | eric.smith | 2008-02-21 00:34:22 +0100 (Thu, 21 Feb 2008) | 1 line
  Trim leading zeros from a floating point exponent, per C99.  See issue 1600.  As far as I know, this only affects Windows.  Add float type 'n' to PyOS_ascii_formatd (see PEP 3101 for 'n' description).
........
  r60910 | eric.smith | 2008-02-21 00:39:28 +0100 (Thu, 21 Feb 2008) | 1 line
  Now that PyOS_ascii_formatd supports the 'n' format, simplify the float formatting code to just call it.
........
  r60918 | andrew.kuchling | 2008-02-21 15:23:38 +0100 (Thu, 21 Feb 2008) | 2 lines
  Close manifest file.
  This change doesn't make any difference to CPython, but is a necessary fix for Jython.
........
  r60921 | guido.van.rossum | 2008-02-21 18:46:16 +0100 (Thu, 21 Feb 2008) | 2 lines
  Remove news about float repr() -- issue 1580 is still in limbo.
........
  r60923 | guido.van.rossum | 2008-02-21 19:18:37 +0100 (Thu, 21 Feb 2008) | 5 lines
  Removed uses of dict.has_key() from distutils, and uses of
  callable() from copy_reg.py, so the interpreter now starts up
  without warnings when '-3' is given.  More work like this needs to
  be done in the rest of the stdlib.
........
  r60924 | thomas.heller | 2008-02-21 19:28:48 +0100 (Thu, 21 Feb 2008) | 4 lines
  configure.ac: Remove the configure check for _Bool, it is already done in the
  top-level Python configure script.
  configure, fficonfig.h.in: regenerated.
........
  r60925 | thomas.heller | 2008-02-21 19:52:20 +0100 (Thu, 21 Feb 2008) | 3 lines
  Replace 'has_key()' with 'in'.
  Replace 'raise Error, stuff' with 'raise Error(stuff)'.
........
  r60927 | raymond.hettinger | 2008-02-21 20:24:53 +0100 (Thu, 21 Feb 2008) | 1 line
  Update more instances of has_key().
........
  r60928 | guido.van.rossum | 2008-02-21 20:46:35 +0100 (Thu, 21 Feb 2008) | 3 lines
  Fix a few typos and layout glitches (more work is needed).
  Move 2.5 news to Misc/HISTORY.
........
  r60936 | georg.brandl | 2008-02-21 21:33:38 +0100 (Thu, 21 Feb 2008) | 2 lines
  #2079: typo in userdict docs.
........
  r60938 | georg.brandl | 2008-02-21 21:38:13 +0100 (Thu, 21 Feb 2008) | 2 lines
  Part of #2154: minimal syntax fixes in doc example snippets.
........
  r60942 | raymond.hettinger | 2008-02-22 04:16:42 +0100 (Fri, 22 Feb 2008) | 1 line
  First draft for itertools.product().  Docs and other updates forthcoming.
........
  r60955 | nick.coghlan | 2008-02-22 11:54:06 +0100 (Fri, 22 Feb 2008) | 1 line
  Try to make command line error messages from runpy easier to understand (and suppress traceback cruft from the implicitly invoked runpy machinery)
........
  r60956 | georg.brandl | 2008-02-22 13:31:45 +0100 (Fri, 22 Feb 2008) | 2 lines
  A lot more typo fixes by Ori Avtalion.
........
  r60957 | georg.brandl | 2008-02-22 13:56:34 +0100 (Fri, 22 Feb 2008) | 2 lines
  Don't reference pyshell.
........
  r60958 | georg.brandl | 2008-02-22 13:57:05 +0100 (Fri, 22 Feb 2008) | 2 lines
  Another fix.
........
											
										 
											2008-02-22 16:37:40 +00:00
										 |  |  |      File "<stdin>", line 1, in <module>
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |        d['primary']                # entry was automatically removed
 | 
					
						
							| 
									
										
										
										
											2018-01-31 17:44:09 -05:00
										 |  |  |      File "C:/python38/lib/weakref.py", line 46, in __getitem__
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |        o = self.data[key]()
 | 
					
						
							|  |  |  |    KeyError: 'primary'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. _tut-list-tools:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Tools for Working with Lists
 | 
					
						
							|  |  |  | ============================
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Many data structure needs can be met with the built-in list type. However,
 | 
					
						
							|  |  |  | sometimes there is a need for alternative implementations with different
 | 
					
						
							|  |  |  | performance trade-offs.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-09 09:54:46 +03:00
										 |  |  | The :mod:`array` module provides an :class:`~array.array()` object that is like
 | 
					
						
							|  |  |  | a list that stores only homogeneous data and stores it more compactly.  The
 | 
					
						
							|  |  |  | following example shows an array of numbers stored as two byte unsigned binary
 | 
					
						
							|  |  |  | numbers (typecode ``"H"``) rather than the usual 16 bytes per entry for regular
 | 
					
						
							|  |  |  | lists of Python int objects::
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    >>> from array import array
 | 
					
						
							|  |  |  |    >>> a = array('H', [4000, 10, 700, 22222])
 | 
					
						
							|  |  |  |    >>> sum(a)
 | 
					
						
							|  |  |  |    26932
 | 
					
						
							|  |  |  |    >>> a[1:3]
 | 
					
						
							|  |  |  |    array('H', [10, 700])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-09 09:54:46 +03:00
										 |  |  | The :mod:`collections` module provides a :class:`~collections.deque()` object
 | 
					
						
							|  |  |  | that is like a list with faster appends and pops from the left side but slower
 | 
					
						
							|  |  |  | lookups in the middle. These objects are well suited for implementing queues
 | 
					
						
							|  |  |  | and breadth first tree searches::
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    >>> from collections import deque
 | 
					
						
							|  |  |  |    >>> d = deque(["task1", "task2", "task3"])
 | 
					
						
							|  |  |  |    >>> d.append("task4")
 | 
					
						
							| 
									
										
										
										
											2007-08-31 03:25:11 +00:00
										 |  |  |    >>> print("Handling", d.popleft())
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    Handling task1
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-24 17:30:39 +03:00
										 |  |  | ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    unsearched = deque([starting_node])
 | 
					
						
							|  |  |  |    def breadth_first_search(unsearched):
 | 
					
						
							|  |  |  |        node = unsearched.popleft()
 | 
					
						
							|  |  |  |        for m in gen_moves(node):
 | 
					
						
							|  |  |  |            if is_goal(m):
 | 
					
						
							|  |  |  |                return m
 | 
					
						
							|  |  |  |            unsearched.append(m)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | In addition to alternative list implementations, the library also offers other
 | 
					
						
							|  |  |  | tools such as the :mod:`bisect` module with functions for manipulating sorted
 | 
					
						
							|  |  |  | lists::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    >>> import bisect
 | 
					
						
							|  |  |  |    >>> scores = [(100, 'perl'), (200, 'tcl'), (400, 'lua'), (500, 'python')]
 | 
					
						
							|  |  |  |    >>> bisect.insort(scores, (300, 'ruby'))
 | 
					
						
							|  |  |  |    >>> scores
 | 
					
						
							|  |  |  |    [(100, 'perl'), (200, 'tcl'), (300, 'ruby'), (400, 'lua'), (500, 'python')]
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The :mod:`heapq` module provides functions for implementing heaps based on
 | 
					
						
							|  |  |  | regular lists.  The lowest valued entry is always kept at position zero.  This
 | 
					
						
							|  |  |  | is useful for applications which repeatedly access the smallest element but do
 | 
					
						
							|  |  |  | not want to run a full list sort::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    >>> from heapq import heapify, heappop, heappush
 | 
					
						
							|  |  |  |    >>> data = [1, 3, 5, 7, 9, 2, 4, 6, 8, 0]
 | 
					
						
							|  |  |  |    >>> heapify(data)                      # rearrange the list into heap order
 | 
					
						
							|  |  |  |    >>> heappush(data, -5)                 # add a new entry
 | 
					
						
							|  |  |  |    >>> [heappop(data) for i in range(3)]  # fetch the three smallest entries
 | 
					
						
							|  |  |  |    [-5, 0, 1]
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. _tut-decimal-fp:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Decimal Floating Point Arithmetic
 | 
					
						
							|  |  |  | =================================
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-09 09:54:46 +03:00
										 |  |  | The :mod:`decimal` module offers a :class:`~decimal.Decimal` datatype for
 | 
					
						
							|  |  |  | decimal floating point arithmetic.  Compared to the built-in :class:`float`
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 74074,74077,74111,74188,74192-74193,74200,74252-74253,74258-74261 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r74074 | georg.brandl | 2009-07-18 05:03:10 -0400 (Sat, 18 Jul 2009) | 1 line
  #6513: fix example code: warning categories are classes, not instances.
........
  r74077 | georg.brandl | 2009-07-18 05:43:40 -0400 (Sat, 18 Jul 2009) | 1 line
  #6489: fix an ambiguity in getiterator() documentation.
........
  r74111 | benjamin.peterson | 2009-07-20 09:30:10 -0400 (Mon, 20 Jul 2009) | 1 line
  remove docs for deprecated -p option
........
  r74188 | benjamin.peterson | 2009-07-23 10:25:31 -0400 (Thu, 23 Jul 2009) | 1 line
  use bools
........
  r74192 | georg.brandl | 2009-07-24 12:28:38 -0400 (Fri, 24 Jul 2009) | 1 line
  Fix arg types of et#.
........
  r74193 | georg.brandl | 2009-07-24 12:46:38 -0400 (Fri, 24 Jul 2009) | 1 line
  Dont put "void" in signature for nullary functions.
........
  r74200 | georg.brandl | 2009-07-25 09:02:15 -0400 (Sat, 25 Jul 2009) | 1 line
  #6571: add index entries for more operators.
........
  r74252 | georg.brandl | 2009-07-29 12:06:31 -0400 (Wed, 29 Jul 2009) | 1 line
  #6593: fix link targets.
........
  r74253 | georg.brandl | 2009-07-29 12:09:17 -0400 (Wed, 29 Jul 2009) | 1 line
  #6591: add reference to ioctl in fcntl module for platforms other than Windows.
........
  r74258 | georg.brandl | 2009-07-29 12:57:05 -0400 (Wed, 29 Jul 2009) | 1 line
  Add a link to readline, and mention IPython and bpython.
........
  r74259 | georg.brandl | 2009-07-29 13:07:21 -0400 (Wed, 29 Jul 2009) | 1 line
  Fix some markup and small factual glitches found by M. Markert.
........
  r74260 | georg.brandl | 2009-07-29 13:15:20 -0400 (Wed, 29 Jul 2009) | 1 line
  Fix a few markup glitches.
........
  r74261 | georg.brandl | 2009-07-29 13:50:25 -0400 (Wed, 29 Jul 2009) | 1 line
  Rewrite the section about classes a bit; mostly tidbits, and a larger update to the section about "private" variables to reflect the Pythonic consensus better.
........
											
										 
											2009-07-29 19:54:39 +00:00
										 |  |  | implementation of binary floating point, the class is especially helpful for
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * financial applications and other uses which require exact decimal
 | 
					
						
							|  |  |  |   representation,
 | 
					
						
							|  |  |  | * control over precision,
 | 
					
						
							|  |  |  | * control over rounding to meet legal or regulatory requirements,
 | 
					
						
							|  |  |  | * tracking of significant decimal places, or
 | 
					
						
							|  |  |  | * applications where the user expects the results to match calculations done by
 | 
					
						
							|  |  |  |   hand.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | For example, calculating a 5% tax on a 70 cent phone charge gives different
 | 
					
						
							|  |  |  | results in decimal floating point and binary floating point. The difference
 | 
					
						
							|  |  |  | becomes significant if the results are rounded to the nearest cent::
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-03 21:18:54 +00:00
										 |  |  |    >>> from decimal import *
 | 
					
						
							| 
									
										
										
										
											2009-06-28 20:59:42 +00:00
										 |  |  |    >>> round(Decimal('0.70') * Decimal('1.05'), 2)
 | 
					
						
							|  |  |  |    Decimal('0.74')
 | 
					
						
							|  |  |  |    >>> round(.70 * 1.05, 2)
 | 
					
						
							|  |  |  |    0.73
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-09 09:54:46 +03:00
										 |  |  | The :class:`~decimal.Decimal` result keeps a trailing zero, automatically
 | 
					
						
							|  |  |  | inferring four place significance from multiplicands with two place
 | 
					
						
							|  |  |  | significance.  Decimal reproduces mathematics as done by hand and avoids
 | 
					
						
							|  |  |  | issues that can arise when binary floating point cannot exactly represent
 | 
					
						
							|  |  |  | decimal quantities.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-09 09:54:46 +03:00
										 |  |  | Exact representation enables the :class:`~decimal.Decimal` class to perform
 | 
					
						
							|  |  |  | modulo calculations and equality tests that are unsuitable for binary floating
 | 
					
						
							|  |  |  | point::
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    >>> Decimal('1.00') % Decimal('.10')
 | 
					
						
							| 
									
										
										
										
											2009-06-28 21:24:42 +00:00
										 |  |  |    Decimal('0.00')
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    >>> 1.00 % 0.10
 | 
					
						
							|  |  |  |    0.09999999999999995
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    >>> sum([Decimal('0.1')]*10) == Decimal('1.0')
 | 
					
						
							|  |  |  |    True
 | 
					
						
							|  |  |  |    >>> sum([0.1]*10) == 1.0
 | 
					
						
							| 
									
										
										
										
											2009-01-03 21:18:54 +00:00
										 |  |  |    False
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | The :mod:`decimal` module provides arithmetic with as much precision as needed::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    >>> getcontext().prec = 36
 | 
					
						
							|  |  |  |    >>> Decimal(1) / Decimal(7)
 | 
					
						
							| 
									
										
										
										
											2009-06-28 21:24:42 +00:00
										 |  |  |    Decimal('0.142857142857142857142857142857142857')
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 |