mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 15:58:57 +00:00 
			
		
		
		
	 c5605dffdb
			
		
	
	
		c5605dffdb
		
	
	
	
	
		
			
			svn+ssh://svn.python.org/python/branches/py3k
................
  r73941 | georg.brandl | 2009-07-11 12:39:00 +0200 (Sa, 11 Jul 2009) | 9 lines
  Merged revisions 73940 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r73940 | georg.brandl | 2009-07-11 12:37:38 +0200 (Sa, 11 Jul 2009) | 1 line
    #6430: add note about size of "u" type.
  ........
................
  r73942 | georg.brandl | 2009-07-11 12:39:23 +0200 (Sa, 11 Jul 2009) | 1 line
  #6430: remove mention of "w" array typecode.
................
  r73943 | georg.brandl | 2009-07-11 12:43:08 +0200 (Sa, 11 Jul 2009) | 1 line
  #6421: The self argument of module-level PyCFunctions is now a reference to the module object.
................
  r74076 | georg.brandl | 2009-07-18 11:07:48 +0200 (Sa, 18 Jul 2009) | 1 line
  #6502: add missing comma in docstring.
................
  r74094 | georg.brandl | 2009-07-19 09:25:56 +0200 (So, 19 Jul 2009) | 10 lines
  Recorded merge of revisions 74089 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r74089 | senthil.kumaran | 2009-07-19 04:43:43 +0200 (So, 19 Jul 2009) | 3 lines
    Fix for issue5102, timeout value propages between redirects, proxy, digest and
    auth handlers. Fixed tests to reflect the same.
  ........
................
  r74186 | georg.brandl | 2009-07-23 11:19:09 +0200 (Do, 23 Jul 2009) | 9 lines
  Recorded merge of revisions 74185 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r74185 | georg.brandl | 2009-07-23 11:17:09 +0200 (Do, 23 Jul 2009) | 1 line
    Fix the "pylocals" gdb command.
  ........
................
  r74211 | georg.brandl | 2009-07-26 16:48:09 +0200 (So, 26 Jul 2009) | 9 lines
  Recorded merge of revisions 74210 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r74210 | georg.brandl | 2009-07-26 16:44:23 +0200 (So, 26 Jul 2009) | 1 line
    Move member descriptions inside the classes.
  ........
................
  r74212 | georg.brandl | 2009-07-26 16:54:51 +0200 (So, 26 Jul 2009) | 9 lines
  Merged revisions 74209 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r74209 | georg.brandl | 2009-07-26 16:37:28 +0200 (So, 26 Jul 2009) | 1 line
    builtin -> built-in.
  ........
................
  r74213 | georg.brandl | 2009-07-26 17:02:41 +0200 (So, 26 Jul 2009) | 9 lines
  Merged revisions 74207 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r74207 | georg.brandl | 2009-07-26 16:19:57 +0200 (So, 26 Jul 2009) | 1 line
    #6577: fix (hopefully) all links to builtin instead of module/class-specific objects.
  ........
................
  r74214 | georg.brandl | 2009-07-26 17:03:49 +0200 (So, 26 Jul 2009) | 9 lines
  Merged revisions 74205 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r74205 | georg.brandl | 2009-07-26 15:36:39 +0200 (So, 26 Jul 2009) | 1 line
    #6576: fix cross-refs in re docs.
  ........
................
  r74247 | georg.brandl | 2009-07-29 09:27:08 +0200 (Mi, 29 Jul 2009) | 9 lines
  Merged revisions 74239 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r74239 | georg.brandl | 2009-07-28 18:55:32 +0000 (Di, 28 Jul 2009) | 1 line
    Clarify quote_plus() usage.
  ........
................
  r74254 | georg.brandl | 2009-07-29 18:14:16 +0200 (Mi, 29 Jul 2009) | 1 line
  #6586: fix return/argument type doc for os.read() and os.write().
................
  r74262 | alexandre.vassalotti | 2009-07-29 21:54:39 +0200 (Mi, 29 Jul 2009) | 57 lines
  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.
  ........
................
  r74311 | georg.brandl | 2009-08-04 22:29:27 +0200 (Di, 04 Aug 2009) | 1 line
  Slightly improve buffer-related error message.
................
  r74334 | georg.brandl | 2009-08-06 19:51:03 +0200 (Do, 06 Aug 2009) | 1 line
  #6648: mention surrogateescape handler where all standard handlers are listed.
................
  r74368 | georg.brandl | 2009-08-13 09:56:35 +0200 (Do, 13 Aug 2009) | 21 lines
  Merged revisions 74328,74332-74333,74365 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk
  ........
    r74328 | georg.brandl | 2009-08-06 17:06:25 +0200 (Do, 06 Aug 2009) | 1 line
    Fix base keyword arg name for int() and long().
  ........
    r74332 | georg.brandl | 2009-08-06 19:23:21 +0200 (Do, 06 Aug 2009) | 1 line
    Fix punctuation and one copy-paste error.
  ........
    r74333 | georg.brandl | 2009-08-06 19:43:55 +0200 (Do, 06 Aug 2009) | 1 line
    #6658: fix two typos.
  ........
    r74365 | georg.brandl | 2009-08-13 09:48:05 +0200 (Do, 13 Aug 2009) | 1 line
    #6679: Remove mention that sub supports no flags.
  ........
................
		
	
			
		
			
				
	
	
		
			326 lines
		
	
	
	
		
			13 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			326 lines
		
	
	
	
		
			13 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| :mod:`dbm` --- Interfaces to Unix "databases"
 | |
| =============================================
 | |
| 
 | |
| .. module:: dbm
 | |
|    :synopsis: Interfaces to various Unix "database" formats.
 | |
| 
 | |
| :mod:`dbm` is a generic interface to variants of the DBM database ---
 | |
|  :mod:`dbm.gnu` or :mod:`dbm.ndbm`.  If none of these modules is installed, the
 | |
|  slow-but-simple implementation in module :mod:`dbm.dumb` will be used.  There
 | |
|  is a `third party interface <http://www.jcea.es/programacion/pybsddb.htm>`_ to
 | |
|  the Oracle Berkely DB.
 | |
| 
 | |
| 
 | |
| .. exception:: error
 | |
| 
 | |
|    A tuple containing the exceptions that can be raised by each of the supported
 | |
|    modules, with a unique exception also named :exc:`dbm.error` as the first
 | |
|    item --- the latter is used when :exc:`dbm.error` is raised.
 | |
| 
 | |
| 
 | |
| .. function:: whichdb(filename)
 | |
| 
 | |
|    This functionattempts to guess which of the several simple database modules
 | |
|    available --- :mod:`dbm.bsd`, :mod:`dbm.gnu`, :mod:`dbm.ndbm` or
 | |
|    :mod:`dbm.dumb` --- should be used to open a given file.
 | |
| 
 | |
|    Returns one of the following values: ``None`` if the file can't be opened
 | |
|    because it's unreadable or doesn't exist; the empty string (``''``) if the
 | |
|    file's format can't be guessed; or a string containing the required module
 | |
|    name, such as ``'dbm.ndbm'`` or ``'dbm.gnu'``.
 | |
| 
 | |
| 
 | |
| .. function:: open(filename, flag='r', mode=0o666)
 | |
| 
 | |
|    Open the database file *filename* and return a corresponding object.
 | |
| 
 | |
|    If the database file already exists, the :func:`whichdb` function is used to
 | |
|    determine its type and the appropriate module is used; if it does not exist,
 | |
|    the first module listed above that can be imported is used.
 | |
| 
 | |
|    The optional *flag* argument can be:
 | |
| 
 | |
|    +---------+-------------------------------------------+
 | |
|    | Value   | Meaning                                   |
 | |
|    +=========+===========================================+
 | |
|    | ``'r'`` | Open existing database for reading only   |
 | |
|    |         | (default)                                 |
 | |
|    +---------+-------------------------------------------+
 | |
|    | ``'w'`` | Open existing database for reading and    |
 | |
|    |         | writing                                   |
 | |
|    +---------+-------------------------------------------+
 | |
|    | ``'c'`` | Open database for reading and writing,    |
 | |
|    |         | creating it if it doesn't exist           |
 | |
|    +---------+-------------------------------------------+
 | |
|    | ``'n'`` | Always create a new, empty database, open |
 | |
|    |         | for reading and writing                   |
 | |
|    +---------+-------------------------------------------+
 | |
| 
 | |
|    The optional *mode* argument is the Unix mode of the file, used only when the
 | |
|    database has to be created.  It defaults to octal ``0o666`` (and will be
 | |
|    modified by the prevailing umask).
 | |
| 
 | |
| 
 | |
| The object returned by :func:`.open` supports most of the same functionality as
 | |
| dictionaries; keys and their corresponding values can be stored, retrieved, and
 | |
| deleted, and the :keyword:`in` operator and the :meth:`keys` method are
 | |
| available. Key and values are always stored as bytes. This means that when
 | |
| strings are used they are implicitly converted to the default encoding before
 | |
| being stored.
 | |
| 
 | |
| The following example records some hostnames and a corresponding title,  and
 | |
| then prints out the contents of the database::
 | |
| 
 | |
|    import dbm
 | |
| 
 | |
|    # Open database, creating it if necessary.
 | |
|    db = dbm.open('cache', 'c')
 | |
| 
 | |
|    # Record some values
 | |
|    db[b'hello'] = b'there'
 | |
|    db['www.python.org'] = 'Python Website'
 | |
|    db['www.cnn.com'] = 'Cable News Network'
 | |
| 
 | |
|    # Note that the keys are considered bytes now.
 | |
|    assert db[b'www.python.org'] == b'Python Website'
 | |
|    # Notice how the value is now in bytes.
 | |
|    assert db['www.cnn.com'] == b'Cable News Network'
 | |
| 
 | |
|    # Loop through contents.  Other dictionary methods
 | |
|    # such as .keys(), .values() also work.
 | |
|    for k, v in db.iteritems():
 | |
|        print(k, '\t', v)
 | |
| 
 | |
|    # Storing a non-string key or value will raise an exception (most
 | |
|    # likely a TypeError).
 | |
|    db['www.yahoo.com'] = 4
 | |
| 
 | |
|    # Close when done.
 | |
|    db.close()
 | |
| 
 | |
| 
 | |
| .. seealso::
 | |
| 
 | |
|    Module :mod:`shelve`
 | |
|       Persistence module which stores non-string data.
 | |
| 
 | |
| 
 | |
| The individual submodules are described in the following sections.
 | |
| 
 | |
| 
 | |
| :mod:`dbm.gnu` --- GNU's reinterpretation of dbm
 | |
| ------------------------------------------------
 | |
| 
 | |
| .. module:: dbm.gnu
 | |
|    :platform: Unix
 | |
|    :synopsis: GNU's reinterpretation of dbm.
 | |
| 
 | |
| 
 | |
| This module is quite similar to the :mod:`dbm` module, but uses the GNU library
 | |
| ``gdbm`` instead to provide some additional functionality.  Please note that the
 | |
| file formats created by :mod:`dbm.gnu` and :mod:`dbm.ndbm` are incompatible.
 | |
| 
 | |
| The :mod:`dbm.gnu` module provides an interface to the GNU DBM library.
 | |
| ``dbm.gnu.gdbm`` objects behave like mappings (dictionaries), except that keys and
 | |
| values are always converted to bytes before storing.  Printing a ``gdbm``
 | |
| object doesn't print the
 | |
| keys and values, and the :meth:`items` and :meth:`values` methods are not
 | |
| supported.
 | |
| 
 | |
| .. exception:: error
 | |
| 
 | |
|    Raised on :mod:`dbm.gnu`-specific errors, such as I/O errors. :exc:`KeyError` is
 | |
|    raised for general mapping errors like specifying an incorrect key.
 | |
| 
 | |
| 
 | |
| .. function:: open(filename[, flag[, mode]])
 | |
| 
 | |
|    Open a ``gdbm`` database and return a :class:`gdbm` object.  The *filename*
 | |
|    argument is the name of the database file.
 | |
| 
 | |
|    The optional *flag* argument can be:
 | |
| 
 | |
|    +---------+-------------------------------------------+
 | |
|    | Value   | Meaning                                   |
 | |
|    +=========+===========================================+
 | |
|    | ``'r'`` | Open existing database for reading only   |
 | |
|    |         | (default)                                 |
 | |
|    +---------+-------------------------------------------+
 | |
|    | ``'w'`` | Open existing database for reading and    |
 | |
|    |         | writing                                   |
 | |
|    +---------+-------------------------------------------+
 | |
|    | ``'c'`` | Open database for reading and writing,    |
 | |
|    |         | creating it if it doesn't exist           |
 | |
|    +---------+-------------------------------------------+
 | |
|    | ``'n'`` | Always create a new, empty database, open |
 | |
|    |         | for reading and writing                   |
 | |
|    +---------+-------------------------------------------+
 | |
| 
 | |
|    The following additional characters may be appended to the flag to control
 | |
|    how the database is opened:
 | |
| 
 | |
|    +---------+--------------------------------------------+
 | |
|    | Value   | Meaning                                    |
 | |
|    +=========+============================================+
 | |
|    | ``'f'`` | Open the database in fast mode.  Writes    |
 | |
|    |         | to the database will not be synchronized.  |
 | |
|    +---------+--------------------------------------------+
 | |
|    | ``'s'`` | Synchronized mode. This will cause changes |
 | |
|    |         | to the database to be immediately written  |
 | |
|    |         | to the file.                               |
 | |
|    +---------+--------------------------------------------+
 | |
|    | ``'u'`` | Do not lock database.                      |
 | |
|    +---------+--------------------------------------------+
 | |
| 
 | |
|    Not all flags are valid for all versions of ``gdbm``.  The module constant
 | |
|    :const:`open_flags` is a string of supported flag characters.  The exception
 | |
|    :exc:`error` is raised if an invalid flag is specified.
 | |
| 
 | |
|    The optional *mode* argument is the Unix mode of the file, used only when the
 | |
|    database has to be created.  It defaults to octal ``0o666``.
 | |
| 
 | |
|    In addition to the dictionary-like methods, ``gdbm`` objects have the
 | |
|    following methods:
 | |
| 
 | |
|    .. method:: gdbm.firstkey()
 | |
| 
 | |
|       It's possible to loop over every key in the database using this method  and the
 | |
|       :meth:`nextkey` method.  The traversal is ordered by ``gdbm``'s internal
 | |
|       hash values, and won't be sorted by the key values.  This method returns
 | |
|       the starting key.
 | |
| 
 | |
|    .. method:: gdbm.nextkey(key)
 | |
| 
 | |
|       Returns the key that follows *key* in the traversal.  The following code prints
 | |
|       every key in the database ``db``, without having to create a list in memory that
 | |
|       contains them all::
 | |
| 
 | |
|          k = db.firstkey()
 | |
|          while k != None:
 | |
|              print(k)
 | |
|              k = db.nextkey(k)
 | |
| 
 | |
|    .. method:: gdbm.reorganize()
 | |
| 
 | |
|       If you have carried out a lot of deletions and would like to shrink the space
 | |
|       used by the ``gdbm`` file, this routine will reorganize the database.  ``gdbm``
 | |
|       objects will not shorten the length of a database file except by using this
 | |
|       reorganization; otherwise, deleted file space will be kept and reused as new
 | |
|       (key, value) pairs are added.
 | |
| 
 | |
|    .. method:: gdbm.sync()
 | |
| 
 | |
|       When the database has been opened in fast mode, this method forces any
 | |
|       unwritten data to be written to the disk.
 | |
| 
 | |
| 
 | |
| :mod:`dbm.ndbm` --- Interface based on ndbm
 | |
| -------------------------------------------
 | |
| 
 | |
| .. module:: dbm.ndbm
 | |
|    :platform: Unix
 | |
|    :synopsis: The standard "database" interface, based on ndbm.
 | |
| 
 | |
| 
 | |
| The :mod:`dbm.ndbm` module provides an interface to the Unix "(n)dbm" library.
 | |
| Dbm objects behave like mappings (dictionaries), except that keys and values are
 | |
| always stored as bytes. Printing a ``dbm`` object doesn't print the keys and
 | |
| values, and the :meth:`items` and :meth:`values` methods are not supported.
 | |
| 
 | |
| This module can be used with the "classic" ndbm interface, the BSD DB
 | |
| compatibility interface, or the GNU GDBM compatibility interface. On Unix, the
 | |
| :program:`configure` script will attempt to locate the appropriate header file
 | |
| to simplify building this module.
 | |
| 
 | |
| .. exception:: error
 | |
| 
 | |
|    Raised on :mod:`dbm.ndbm`-specific errors, such as I/O errors. :exc:`KeyError` is raised
 | |
|    for general mapping errors like specifying an incorrect key.
 | |
| 
 | |
| 
 | |
| .. data:: library
 | |
| 
 | |
|    Name of the ``ndbm`` implementation library used.
 | |
| 
 | |
| 
 | |
| .. function:: open(filename[, flag[, mode]])
 | |
| 
 | |
|    Open a dbm database and return a ``dbm`` object.  The *filename* argument is the
 | |
|    name of the database file (without the :file:`.dir` or :file:`.pag` extensions;
 | |
|    note that the BSD DB implementation of the interface will append the extension
 | |
|    :file:`.db` and only create one file).
 | |
| 
 | |
|    The optional *flag* argument must be one of these values:
 | |
| 
 | |
|    +---------+-------------------------------------------+
 | |
|    | Value   | Meaning                                   |
 | |
|    +=========+===========================================+
 | |
|    | ``'r'`` | Open existing database for reading only   |
 | |
|    |         | (default)                                 |
 | |
|    +---------+-------------------------------------------+
 | |
|    | ``'w'`` | Open existing database for reading and    |
 | |
|    |         | writing                                   |
 | |
|    +---------+-------------------------------------------+
 | |
|    | ``'c'`` | Open database for reading and writing,    |
 | |
|    |         | creating it if it doesn't exist           |
 | |
|    +---------+-------------------------------------------+
 | |
|    | ``'n'`` | Always create a new, empty database, open |
 | |
|    |         | for reading and writing                   |
 | |
|    +---------+-------------------------------------------+
 | |
| 
 | |
|    The optional *mode* argument is the Unix mode of the file, used only when the
 | |
|    database has to be created.  It defaults to octal ``0o666`` (and will be
 | |
|    modified by the prevailing umask).
 | |
| 
 | |
| 
 | |
| 
 | |
| :mod:`dbm.dumb` --- Portable DBM implementation
 | |
| -----------------------------------------------
 | |
| 
 | |
| .. module:: dbm.dumb
 | |
|    :synopsis: Portable implementation of the simple DBM interface.
 | |
| 
 | |
| .. index:: single: databases
 | |
| 
 | |
| .. note::
 | |
| 
 | |
|    The :mod:`dbm.dumb` module is intended as a last resort fallback for the
 | |
|    :mod:`dbm` module when a more robust module is not available. The :mod:`dbm.dumb`
 | |
|    module is not written for speed and is not nearly as heavily used as the other
 | |
|    database modules.
 | |
| 
 | |
| The :mod:`dbm.dumb` module provides a persistent dictionary-like interface which
 | |
| is written entirely in Python.  Unlike other modules such as :mod:`dbm.gnu` no
 | |
| external library is required.  As with other persistent mappings, the keys and
 | |
| values are always stored as bytes.
 | |
| 
 | |
| The module defines the following:
 | |
| 
 | |
| 
 | |
| .. exception:: error
 | |
| 
 | |
|    Raised on :mod:`dbm.dumb`-specific errors, such as I/O errors.  :exc:`KeyError` is
 | |
|    raised for general mapping errors like specifying an incorrect key.
 | |
| 
 | |
| 
 | |
| .. function:: open(filename[, flag[, mode]])
 | |
| 
 | |
|    Open a ``dumbdbm`` database and return a dumbdbm object.  The *filename* argument is
 | |
|    the basename of the database file (without any specific extensions).  When a
 | |
|    dumbdbm database is created, files with :file:`.dat` and :file:`.dir` extensions
 | |
|    are created.
 | |
| 
 | |
|    The optional *flag* argument is currently ignored; the database is always opened
 | |
|    for update, and will be created if it does not exist.
 | |
| 
 | |
|    The optional *mode* argument is the Unix mode of the file, used only when the
 | |
|    database has to be created.  It defaults to octal ``0o666`` (and will be modified
 | |
|    by the prevailing umask).
 | |
| 
 | |
|    In addition to the methods provided by the :class:`collections.MutableMapping` class,
 | |
|    :class:`dumbdbm` objects provide the following method:
 | |
| 
 | |
|    .. method:: dumbdbm.sync()
 | |
| 
 | |
|       Synchronize the on-disk directory and data files.  This method is called
 | |
|       by the :meth:`Shelve.sync` method.
 |