mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 13:41:24 +00:00 
			
		
		
		
	 4ac9ce4f9a
			
		
	
	
		4ac9ce4f9a
		
	
	
	
	
		
			
			svn+ssh://pythondev@svn.python.org/python/trunk ........ r74779 | michael.foord | 2009-09-13 11:13:36 -0500 (Sun, 13 Sep 2009) | 1 line Change to tutorial wording for reading text / binary files on Windows. Issue #6301. ........ r74780 | michael.foord | 2009-09-13 11:40:02 -0500 (Sun, 13 Sep 2009) | 1 line Objects that compare equal automatically pass or fail assertAlmostEqual and assertNotAlmostEqual tests on unittest.TestCase. Issue 6567. ........ r74781 | michael.foord | 2009-09-13 11:46:19 -0500 (Sun, 13 Sep 2009) | 1 line Note that sys._getframe is not guaranteed to exist in all implementations of Python, and a corresponding note in inspect.currentframe. Issue 6712. ........ r74782 | michael.foord | 2009-09-13 12:07:46 -0500 (Sun, 13 Sep 2009) | 1 line Tutorial tweaks. Issue 6849. ........ r74783 | michael.foord | 2009-09-13 12:28:35 -0500 (Sun, 13 Sep 2009) | 1 line unittest.TestLoader.loadTestsFromName honors the loader suiteClass attribute. Issue 6866. ........ r74784 | georg.brandl | 2009-09-13 13:15:07 -0500 (Sun, 13 Sep 2009) | 1 line Typo fix. ........ r74785 | michael.foord | 2009-09-13 14:07:03 -0500 (Sun, 13 Sep 2009) | 1 line Test discovery in unittest will only attempt to import modules that are importable; i.e. their names are valid Python identifiers. If an import fails during discovery this will be recorded as an error and test discovery will continue. Issue 6568. ........ r74786 | michael.foord | 2009-09-13 14:08:18 -0500 (Sun, 13 Sep 2009) | 1 line Remove an extraneous space in unittest documentation. ........ r74793 | georg.brandl | 2009-09-14 09:50:47 -0500 (Mon, 14 Sep 2009) | 1 line #6908: fix association of hashlib hash attributes. ........ r74795 | benjamin.peterson | 2009-09-14 22:36:26 -0500 (Mon, 14 Sep 2009) | 1 line Py_SetPythonHome uses static storage #6913 ........ r74811 | georg.brandl | 2009-09-15 15:26:59 -0500 (Tue, 15 Sep 2009) | 1 line Add Armin Ronacher. ........ r74860 | benjamin.peterson | 2009-09-16 21:46:54 -0500 (Wed, 16 Sep 2009) | 1 line kill bare except ........ r74861 | benjamin.peterson | 2009-09-16 22:18:28 -0500 (Wed, 16 Sep 2009) | 1 line pep 8 defaults ........ r74863 | benjamin.peterson | 2009-09-16 22:27:33 -0500 (Wed, 16 Sep 2009) | 1 line rationalize a bit ........ r74876 | georg.brandl | 2009-09-17 11:15:53 -0500 (Thu, 17 Sep 2009) | 1 line #6932: remove paragraph that advises relying on __del__ being called. ........ r74886 | benjamin.peterson | 2009-09-17 16:33:46 -0500 (Thu, 17 Sep 2009) | 1 line use macros ........ r74896 | georg.brandl | 2009-09-18 02:22:41 -0500 (Fri, 18 Sep 2009) | 1 line #6936: for interactive use, quit() is just fine. ........ r74901 | georg.brandl | 2009-09-18 04:14:52 -0500 (Fri, 18 Sep 2009) | 1 line #6905: use better exception messages in inspect when the argument is of the wrong type. ........ r74903 | georg.brandl | 2009-09-18 04:18:27 -0500 (Fri, 18 Sep 2009) | 1 line #6938: "ident" is always a string, so use a format code which works. ........ r74908 | georg.brandl | 2009-09-18 08:57:11 -0500 (Fri, 18 Sep 2009) | 1 line Use str.format() to fix beginner's mistake with %-style string formatting. ........ r74912 | georg.brandl | 2009-09-18 11:19:56 -0500 (Fri, 18 Sep 2009) | 1 line Optimize optimization and fix method name in docstring. ........ r74930 | georg.brandl | 2009-09-18 16:21:41 -0500 (Fri, 18 Sep 2009) | 1 line #6925: rewrite docs for locals() and vars() a bit. ........ r74933 | georg.brandl | 2009-09-18 16:35:59 -0500 (Fri, 18 Sep 2009) | 1 line #6930: clarify description about byteorder handling in UTF decoder routines. ........ r74943 | georg.brandl | 2009-09-19 02:35:07 -0500 (Sat, 19 Sep 2009) | 1 line #6944: the argument to PyArg_ParseTuple should be a tuple, otherwise a SystemError is set. Also clean up another usage of PyArg_ParseTuple. ........ r74946 | georg.brandl | 2009-09-19 03:43:16 -0500 (Sat, 19 Sep 2009) | 1 line Update bug tracker reference. ........ r74952 | georg.brandl | 2009-09-19 05:42:34 -0500 (Sat, 19 Sep 2009) | 1 line #6946: fix duplicate index entries for datetime classes. ........ r74953 | georg.brandl | 2009-09-19 07:04:16 -0500 (Sat, 19 Sep 2009) | 1 line Fix references to threading.enumerate(). ........ r74954 | georg.brandl | 2009-09-19 08:13:56 -0500 (Sat, 19 Sep 2009) | 1 line Add Doug. ........ r74955 | georg.brandl | 2009-09-19 08:20:49 -0500 (Sat, 19 Sep 2009) | 1 line Add Mark Summerfield. ........ r75015 | georg.brandl | 2009-09-22 05:55:08 -0500 (Tue, 22 Sep 2009) | 1 line Fix encoding name. ........ r75019 | vinay.sajip | 2009-09-22 12:23:41 -0500 (Tue, 22 Sep 2009) | 1 line Fixed a typo, and added sections on optimization and using arbitrary objects as messages. ........ r75032 | benjamin.peterson | 2009-09-22 17:15:28 -0500 (Tue, 22 Sep 2009) | 1 line fix typos/rephrase ........ r75068 | benjamin.peterson | 2009-09-25 21:57:59 -0500 (Fri, 25 Sep 2009) | 1 line comment out ugly xxx ........ r75076 | vinay.sajip | 2009-09-26 09:53:32 -0500 (Sat, 26 Sep 2009) | 1 line Tidied up name of parameter in StreamHandler ........ r75095 | michael.foord | 2009-09-27 14:15:41 -0500 (Sun, 27 Sep 2009) | 1 line Test creation moved from TestProgram.parseArgs to TestProgram.createTests exclusively. Issue 6956. ........ r75098 | michael.foord | 2009-09-27 15:08:23 -0500 (Sun, 27 Sep 2009) | 1 line Documentation improvement for load_tests protocol in unittest. Issue 6515. ........ r75102 | skip.montanaro | 2009-09-27 21:12:27 -0500 (Sun, 27 Sep 2009) | 3 lines Patch from Thomas Barr so that csv.Sniffer will set doublequote property. Closes issue 6606. ........ r75129 | vinay.sajip | 2009-09-29 02:08:54 -0500 (Tue, 29 Sep 2009) | 1 line Issue #7014: logging: Improved IronPython 2.6 compatibility. ........ r75139 | raymond.hettinger | 2009-09-29 13:53:24 -0500 (Tue, 29 Sep 2009) | 3 lines Issue 7008: Better document str.title and show how to work around the apostrophe problem. ........ r75230 | benjamin.peterson | 2009-10-04 08:38:38 -0500 (Sun, 04 Oct 2009) | 1 line test logging ........
		
			
				
	
	
		
			180 lines
		
	
	
	
		
			7.3 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			180 lines
		
	
	
	
		
			7.3 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| :mod:`shelve` --- Python object persistence
 | |
| ===========================================
 | |
| 
 | |
| .. module:: shelve
 | |
|    :synopsis: Python object persistence.
 | |
| 
 | |
| 
 | |
| .. index:: module: pickle
 | |
| 
 | |
| A "shelf" is a persistent, dictionary-like object.  The difference with "dbm"
 | |
| databases is that the values (not the keys!) in a shelf can be essentially
 | |
| arbitrary Python objects --- anything that the :mod:`pickle` module can handle.
 | |
| This includes most class instances, recursive data types, and objects containing
 | |
| lots of shared  sub-objects.  The keys are ordinary strings.
 | |
| 
 | |
| 
 | |
| .. function:: open(filename, flag='c', protocol=None, writeback=False)
 | |
| 
 | |
|    Open a persistent dictionary.  The filename specified is the base filename for
 | |
|    the underlying database.  As a side-effect, an extension may be added to the
 | |
|    filename and more than one file may be created.  By default, the underlying
 | |
|    database file is opened for reading and writing.  The optional *flag* parameter
 | |
|    has the same interpretation as the *flag* parameter of :func:`dbm.open`.
 | |
| 
 | |
|    By default, version 3 pickles are used to serialize values.  The version of the
 | |
|    pickle protocol can be specified with the *protocol* parameter.
 | |
| 
 | |
|    Because of Python semantics, a shelf cannot know when a mutable
 | |
|    persistent-dictionary entry is modified.  By default modified objects are
 | |
|    written only when assigned to the shelf (see :ref:`shelve-example`).  If the
 | |
|    optional *writeback* parameter is set to *True*, all entries accessed are
 | |
|    cached in memory, and written back on :meth:`sync` and :meth:`close`; this
 | |
|    can make it handier to mutate mutable entries in the persistent dictionary,
 | |
|    but, if many entries are accessed, it can consume vast amounts of memory for
 | |
|    the cache, and it can make the close operation very slow since all accessed
 | |
|    entries are written back (there is no way to determine which accessed entries
 | |
|    are mutable, nor which ones were actually mutated).
 | |
| 
 | |
|    .. note::
 | |
| 
 | |
|       Do not rely on the shelf being closed automatically; always call
 | |
|       :meth:`close` explicitly when you don't need it any more, or use a
 | |
|       :keyword:`with` statement with :func:`contextlib.closing`.
 | |
| 
 | |
| 
 | |
| Shelf objects support all methods supported by dictionaries.  This eases the
 | |
| transition from dictionary based scripts to those requiring persistent storage.
 | |
| 
 | |
| Two additional methods are supported:
 | |
| 
 | |
| .. method:: Shelf.sync()
 | |
| 
 | |
|    Write back all entries in the cache if the shelf was opened with *writeback*
 | |
|    set to :const:`True`.  Also empty the cache and synchronize the persistent
 | |
|    dictionary on disk, if feasible.  This is called automatically when the shelf
 | |
|    is closed with :meth:`close`.
 | |
| 
 | |
| .. method:: Shelf.close()
 | |
| 
 | |
|    Synchronize and close the persistent *dict* object.  Operations on a closed
 | |
|    shelf will fail with a :exc:`ValueError`.
 | |
| 
 | |
| 
 | |
| .. seealso::
 | |
| 
 | |
|    `Persistent dictionary recipe <http://code.activestate.com/recipes/576642/>`_
 | |
|    with widely supported storage formats and having the speed of native
 | |
|    dictionaries.
 | |
| 
 | |
| 
 | |
| Restrictions
 | |
| ------------
 | |
| 
 | |
|   .. index::
 | |
|      module: dbm.ndbm
 | |
|      module: dbm.gnu
 | |
| 
 | |
| * The choice of which database package will be used (such as :mod:`dbm.ndbm` or
 | |
|   :mod:`dbm.gnu`) depends on which interface is available.  Therefore it is not
 | |
|   safe to open the database directly using :mod:`dbm`.  The database is also
 | |
|   (unfortunately) subject to the limitations of :mod:`dbm`, if it is used ---
 | |
|   this means that (the pickled representation of) the objects stored in the
 | |
|   database should be fairly small, and in rare cases key collisions may cause
 | |
|   the database to refuse updates.
 | |
| 
 | |
| * The :mod:`shelve` module does not support *concurrent* read/write access to
 | |
|   shelved objects.  (Multiple simultaneous read accesses are safe.)  When a
 | |
|   program has a shelf open for writing, no other program should have it open for
 | |
|   reading or writing.  Unix file locking can be used to solve this, but this
 | |
|   differs across Unix versions and requires knowledge about the database
 | |
|   implementation used.
 | |
| 
 | |
| 
 | |
| .. class:: Shelf(dict, protocol=None, writeback=False)
 | |
| 
 | |
|    A subclass of :class:`collections.MutableMapping` which stores pickled values
 | |
|    in the *dict* object.
 | |
| 
 | |
|    By default, version 0 pickles are used to serialize values.  The version of the
 | |
|    pickle protocol can be specified with the *protocol* parameter. See the
 | |
|    :mod:`pickle` documentation for a discussion of the pickle protocols.
 | |
| 
 | |
|    If the *writeback* parameter is ``True``, the object will hold a cache of all
 | |
|    entries accessed and write them back to the *dict* at sync and close times.
 | |
|    This allows natural operations on mutable entries, but can consume much more
 | |
|    memory and make sync and close take a long time.
 | |
| 
 | |
| 
 | |
| .. class:: BsdDbShelf(dict, protocol=None, writeback=False)
 | |
| 
 | |
|    A subclass of :class:`Shelf` which exposes :meth:`first`, :meth:`!next`,
 | |
|    :meth:`previous`, :meth:`last` and :meth:`set_location` which are available
 | |
|    in the third-party :mod:`bsddb` module from `pybsddb
 | |
|    <http://www.jcea.es/programacion/pybsddb.htm>`_ but not in other database
 | |
|    modules.  The *dict* object passed to the constructor must support those
 | |
|    methods.  This is generally accomplished by calling one of
 | |
|    :func:`bsddb.hashopen`, :func:`bsddb.btopen` or :func:`bsddb.rnopen`.  The
 | |
|    optional *protocol* and *writeback* parameters have the same interpretation
 | |
|    as for the :class:`Shelf` class.
 | |
| 
 | |
| 
 | |
| .. class:: DbfilenameShelf(filename, flag='c', protocol=None, writeback=False)
 | |
| 
 | |
|    A subclass of :class:`Shelf` which accepts a *filename* instead of a dict-like
 | |
|    object.  The underlying file will be opened using :func:`dbm.open`.  By
 | |
|    default, the file will be created and opened for both read and write.  The
 | |
|    optional *flag* parameter has the same interpretation as for the :func:`.open`
 | |
|    function.  The optional *protocol* and *writeback* parameters have the same
 | |
|    interpretation as for the :class:`Shelf` class.
 | |
| 
 | |
| 
 | |
| .. _shelve-example:
 | |
| 
 | |
| Example
 | |
| -------
 | |
| 
 | |
| To summarize the interface (``key`` is a string, ``data`` is an arbitrary
 | |
| object)::
 | |
| 
 | |
|    import shelve
 | |
| 
 | |
|    d = shelve.open(filename) # open -- file may get suffix added by low-level
 | |
|                              # library
 | |
| 
 | |
|    d[key] = data   # store data at key (overwrites old data if
 | |
|                    # using an existing key)
 | |
|    data = d[key]   # retrieve a COPY of data at key (raise KeyError if no
 | |
|                    # such key)
 | |
|    del d[key]      # delete data stored at key (raises KeyError
 | |
|                    # if no such key)
 | |
|    flag = key in d        # true if the key exists
 | |
|    klist = list(d.keys()) # a list of all existing keys (slow!)
 | |
| 
 | |
|    # as d was opened WITHOUT writeback=True, beware:
 | |
|    d['xx'] = range(4)  # this works as expected, but...
 | |
|    d['xx'].append(5)   # *this doesn't!* -- d['xx'] is STILL range(4)!
 | |
| 
 | |
|    # having opened d without writeback=True, you need to code carefully:
 | |
|    temp = d['xx']      # extracts the copy
 | |
|    temp.append(5)      # mutates the copy
 | |
|    d['xx'] = temp      # stores the copy right back, to persist it
 | |
| 
 | |
|    # or, d=shelve.open(filename,writeback=True) would let you just code
 | |
|    # d['xx'].append(5) and have it work as expected, BUT it would also
 | |
|    # consume more memory and make the d.close() operation slower.
 | |
| 
 | |
|    d.close()       # close it
 | |
| 
 | |
| 
 | |
| .. seealso::
 | |
| 
 | |
|    Module :mod:`dbm`
 | |
|       Generic interface to ``dbm``-style databases.
 | |
| 
 | |
|    Module :mod:`pickle`
 | |
|       Object serialization used by :mod:`shelve`.
 | |
| 
 | |
|    Module :mod:`cPickle`
 | |
|       High-performance version of :mod:`pickle`.
 | |
| 
 |