2008-05-26 07:29:35 -03:00
|
|
|
:mod:`dbm` --- Interfaces to Unix "databases"
|
|
|
|
=============================================
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
.. module:: dbm
|
2008-05-26 07:29:35 -03:00
|
|
|
:synopsis: Interfaces to various Unix "database" formats.
|
|
|
|
|
|
|
|
:mod:`dbm` is a generic interface to variants of the DBM database ---
|
Merged revisions 83352,83355-83358,83362,83366,83368-83369 via svnmerge from
svn+ssh://svn.python.org/python/branches/py3k
........
r83352 | georg.brandl | 2010-07-31 20:11:07 +0200 (Sa, 31 Jul 2010) | 1 line
#9440: Remove borderline test case that fails based on unpredictable conditions such as compiler flags.
........
r83355 | georg.brandl | 2010-07-31 21:17:11 +0200 (Sa, 31 Jul 2010) | 1 line
Fix bad merge: test_support -> support.
........
r83356 | georg.brandl | 2010-07-31 21:29:15 +0200 (Sa, 31 Jul 2010) | 1 line
Remove trailing whitespace.
........
r83357 | georg.brandl | 2010-07-31 21:59:55 +0200 (Sa, 31 Jul 2010) | 1 line
#5778: document that sys.version can contain a newline.
........
r83358 | georg.brandl | 2010-07-31 22:05:31 +0200 (Sa, 31 Jul 2010) | 1 line
#9442: do not document a specific format for sys.version; rather refer to version_info and the platform module.
........
r83362 | georg.brandl | 2010-07-31 23:12:15 +0200 (Sa, 31 Jul 2010) | 1 line
#8910: add a file explaining why Lib/test/data is there.
........
r83366 | georg.brandl | 2010-07-31 23:26:40 +0200 (Sa, 31 Jul 2010) | 1 line
There always is a False and True now.
........
r83368 | georg.brandl | 2010-07-31 23:40:15 +0200 (Sa, 31 Jul 2010) | 1 line
#7909: the prefixes \\.\ and \\?\ indicate special Windows paths, do not try to manipulate them. See http://msdn.microsoft.com/en-us/library/aa365247%28VS.85%29.aspx for details.
........
r83369 | georg.brandl | 2010-07-31 23:41:42 +0200 (Sa, 31 Jul 2010) | 1 line
Fix "Berkeley" name.
........
2010-08-01 16:17:57 -03:00
|
|
|
: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 Berkeley DB.
|
2008-05-26 07:29:35 -03:00
|
|
|
|
|
|
|
|
|
|
|
.. 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)
|
|
|
|
|
Merged revisions 86537,86867-86868,86881,86887,86913-86915,86931-86933,86960,86964,86974,86980,86996,87008,87050 via svnmerge from
svn+ssh://svn.python.org/python/branches/py3k
........
r86537 | georg.brandl | 2010-11-19 23:09:04 +0100 (Fr, 19 Nov 2010) | 1 line
Do not put a raw REPLACEMENT CHARACTER in the document.
........
r86867 | georg.brandl | 2010-11-29 15:50:54 +0100 (Mo, 29 Nov 2010) | 1 line
Fix indentation bug.
........
r86868 | georg.brandl | 2010-11-29 15:53:15 +0100 (Mo, 29 Nov 2010) | 1 line
Fix heading style inconsistencies.
........
r86881 | georg.brandl | 2010-11-30 08:43:28 +0100 (Di, 30 Nov 2010) | 1 line
#10584: fix bad links.
........
r86887 | georg.brandl | 2010-11-30 15:57:54 +0100 (Di, 30 Nov 2010) | 1 line
Fix typo.
........
r86913 | georg.brandl | 2010-12-01 16:32:43 +0100 (Mi, 01 Dez 2010) | 1 line
Add missing word, and add a better reference to the actual function.
........
r86914 | georg.brandl | 2010-12-01 16:36:33 +0100 (Mi, 01 Dez 2010) | 1 line
#10594: fix parameter names in PyList API docs.
........
r86915 | georg.brandl | 2010-12-01 16:44:25 +0100 (Mi, 01 Dez 2010) | 1 line
Fix some markup and style in the unittest docs.
........
r86931 | georg.brandl | 2010-12-02 10:06:12 +0100 (Do, 02 Dez 2010) | 1 line
Fix-up documentation of makedirs().
........
r86932 | david.malcolm | 2010-12-02 17:41:00 +0100 (Do, 02 Dez 2010) | 2 lines
Fix spelling of Jamie Zawinski's surname in urllib.parse docstring (issue 10606)
........
r86933 | georg.brandl | 2010-12-02 19:02:01 +0100 (Do, 02 Dez 2010) | 1 line
#10597: fix Py_SetPythonHome docs by pointing to where the meaning of PYTHONHOME is already documented.
........
r86960 | georg.brandl | 2010-12-03 08:55:44 +0100 (Fr, 03 Dez 2010) | 1 line
#10360: catch TypeError in WeakSet.__contains__, just like WeakKeyDictionary does.
........
r86964 | georg.brandl | 2010-12-03 10:58:38 +0100 (Fr, 03 Dez 2010) | 1 line
#10549: fix interface of docclass() for text documenter.
........
r86974 | georg.brandl | 2010-12-03 16:30:09 +0100 (Fr, 03 Dez 2010) | 1 line
Markup consistency fixes.
........
r86980 | georg.brandl | 2010-12-03 18:19:27 +0100 (Fr, 03 Dez 2010) | 1 line
Fix punctuation.
........
r86996 | georg.brandl | 2010-12-03 20:56:42 +0100 (Fr, 03 Dez 2010) | 1 line
Fix indentation.
........
r87008 | georg.brandl | 2010-12-04 10:04:04 +0100 (Sa, 04 Dez 2010) | 1 line
Fix typo.
........
r87050 | georg.brandl | 2010-12-04 18:09:30 +0100 (Sa, 04 Dez 2010) | 1 line
Fix typo.
........
2011-02-25 05:48:21 -04:00
|
|
|
This function attempts to guess which of the several simple database modules
|
2010-08-01 18:03:01 -03:00
|
|
|
available --- :mod:`dbm.gnu`, :mod:`dbm.ndbm` or :mod:`dbm.dumb` --- should
|
|
|
|
be used to open a given file.
|
2008-05-26 07:29:35 -03:00
|
|
|
|
|
|
|
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'``.
|
|
|
|
|
|
|
|
|
2009-04-10 06:03:43 -03:00
|
|
|
.. function:: open(filename, flag='r', mode=0o666)
|
2008-05-26 07:29:35 -03:00
|
|
|
|
|
|
|
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.
|
|
|
|
|
2009-05-25 18:15:01 -03:00
|
|
|
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 |
|
|
|
|
+---------+-------------------------------------------+
|
2008-05-26 07:29:35 -03:00
|
|
|
|
|
|
|
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).
|
|
|
|
|
|
|
|
|
Merged revisions 73941-73943,74076,74094,74186,74211-74214,74247,74254,74262,74311,74334,74368 via svnmerge from
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.
........
................
2009-08-13 05:26:44 -03:00
|
|
|
The object returned by :func:`.open` supports most of the same functionality as
|
2008-05-26 07:29:35 -03:00
|
|
|
dictionaries; keys and their corresponding values can be stored, retrieved, and
|
|
|
|
deleted, and the :keyword:`in` operator and the :meth:`keys` method are
|
2008-11-25 15:19:17 -04:00
|
|
|
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.
|
2008-05-26 07:29:35 -03:00
|
|
|
|
|
|
|
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
|
2008-11-25 15:19:17 -04:00
|
|
|
db[b'hello'] = b'there'
|
2008-05-26 07:29:35 -03:00
|
|
|
db['www.python.org'] = 'Python Website'
|
|
|
|
db['www.cnn.com'] = 'Cable News Network'
|
|
|
|
|
2008-11-25 15:19:17 -04:00
|
|
|
# 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'
|
|
|
|
|
Merged revisions 87101,87146,87156,87172,87175,87371,87378,87522-87524,87526-87528,87530-87536,87581 via svnmerge from
svn+ssh://svn.python.org/python/branches/py3k
........
r87101 | georg.brandl | 2010-12-06 23:02:48 +0100 (Mo, 06 Dez 2010) | 1 line
Remove visible XXX comments.
........
r87146 | georg.brandl | 2010-12-09 19:08:43 +0100 (Do, 09 Dez 2010) | 1 line
Fix "seperate".
........
r87156 | georg.brandl | 2010-12-10 11:01:44 +0100 (Fr, 10 Dez 2010) | 1 line
#10668: fix wrong call of __init__.
........
r87172 | georg.brandl | 2010-12-11 20:10:30 +0100 (Sa, 11 Dez 2010) | 1 line
Avoid AttributeError(_closed) when a TemporaryDirectory is deallocated whose mkdtemp call failed.
........
r87175 | georg.brandl | 2010-12-11 23:19:34 +0100 (Sa, 11 Dez 2010) | 1 line
Fix markup.
........
r87371 | georg.brandl | 2010-12-18 17:21:58 +0100 (Sa, 18 Dez 2010) | 1 line
Fix typo.
........
r87378 | georg.brandl | 2010-12-18 18:51:28 +0100 (Sa, 18 Dez 2010) | 1 line
#10723: add missing builtin exceptions.
........
r87522 | georg.brandl | 2010-12-28 10:16:12 +0100 (Di, 28 Dez 2010) | 1 line
Replace sys.maxint mention by sys.maxsize.
........
r87523 | georg.brandl | 2010-12-28 10:18:24 +0100 (Di, 28 Dez 2010) | 1 line
Remove confusing paragraph -- this is relevant only to advanced users anyway and does not belong into the tutorial.
........
r87524 | georg.brandl | 2010-12-28 10:29:19 +0100 (Di, 28 Dez 2010) | 1 line
Fix advice: call PyType_Ready to fill in ob_type of custom types.
........
r87526 | georg.brandl | 2010-12-28 11:38:33 +0100 (Di, 28 Dez 2010) | 1 line
#10777: fix iteration over dict keys while mutating the dict.
........
r87527 | georg.brandl | 2010-12-28 11:56:20 +0100 (Di, 28 Dez 2010) | 1 line
#10768: fix ScrolledText widget construction, and make the example work from the interactive shell.
........
r87528 | georg.brandl | 2010-12-28 12:02:12 +0100 (Di, 28 Dez 2010) | 1 line
Add news entry and clarify another.
........
r87530 | georg.brandl | 2010-12-28 12:06:07 +0100 (Di, 28 Dez 2010) | 1 line
#10767: update README in crashers; not all may have a bug entry and/or be fixed.
........
r87531 | georg.brandl | 2010-12-28 12:08:17 +0100 (Di, 28 Dez 2010) | 1 line
#10742: document readonly attribute of memoryviews.
........
r87532 | georg.brandl | 2010-12-28 12:15:49 +0100 (Di, 28 Dez 2010) | 1 line
#10781: clarify that *encoding* is not a parameter for Node objects in general.
........
r87533 | georg.brandl | 2010-12-28 12:38:12 +0100 (Di, 28 Dez 2010) | 1 line
Remove history; adapt a bit more to reST, since this will once be part of the dev guide.
........
r87534 | georg.brandl | 2010-12-28 12:48:53 +0100 (Di, 28 Dez 2010) | 1 line
Rewrap.
........
r87535 | georg.brandl | 2010-12-28 12:49:41 +0100 (Di, 28 Dez 2010) | 1 line
#10739: document that on Windows, socket.makefile() does not make a file that has a true file descriptor usable where such a thing is expected.
........
r87536 | georg.brandl | 2010-12-28 12:53:25 +0100 (Di, 28 Dez 2010) | 1 line
#10609: fix non-working dbm example.
........
r87581 | georg.brandl | 2010-12-30 18:36:17 +0100 (Do, 30 Dez 2010) | 1 line
Fix NameErrors.
........
2011-02-25 06:03:34 -04:00
|
|
|
# Often-used methods of the dict interface work too.
|
|
|
|
print(db.get('python.org', b'not present'))
|
2008-05-26 07:29:35 -03:00
|
|
|
|
|
|
|
# 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
|
2008-11-25 15:19:17 -04:00
|
|
|
file formats created by :mod:`dbm.gnu` and :mod:`dbm.ndbm` are incompatible.
|
2008-05-26 07:29:35 -03:00
|
|
|
|
|
|
|
The :mod:`dbm.gnu` module provides an interface to the GNU DBM library.
|
2008-11-25 15:19:17 -04:00
|
|
|
``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
|
2008-05-26 07:29:35 -03:00
|
|
|
keys and values, and the :meth:`items` and :meth:`values` methods are not
|
|
|
|
supported.
|
|
|
|
|
|
|
|
.. exception:: error
|
|
|
|
|
2008-11-25 15:19:17 -04:00
|
|
|
Raised on :mod:`dbm.gnu`-specific errors, such as I/O errors. :exc:`KeyError` is
|
2008-05-26 07:29:35 -03:00
|
|
|
raised for general mapping errors like specifying an incorrect key.
|
|
|
|
|
|
|
|
|
2009-04-10 06:03:43 -03:00
|
|
|
.. function:: open(filename[, flag[, mode]])
|
2008-05-26 07:29:35 -03:00
|
|
|
|
|
|
|
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
|
2008-05-26 14:55:52 -03:00
|
|
|
database has to be created. It defaults to octal ``0o666``.
|
2008-05-26 07:29:35 -03:00
|
|
|
|
|
|
|
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``
|
2008-11-25 15:19:17 -04:00
|
|
|
objects will not shorten the length of a database file except by using this
|
2008-05-26 07:29:35 -03:00
|
|
|
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
|
2007-08-15 11:28:22 -03:00
|
|
|
:platform: Unix
|
|
|
|
:synopsis: The standard "database" interface, based on ndbm.
|
|
|
|
|
|
|
|
|
2008-05-26 07:29:35 -03:00
|
|
|
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
|
2008-11-25 15:19:17 -04:00
|
|
|
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.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2010-08-01 18:03:01 -03:00
|
|
|
This module can be used with the "classic" ndbm 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.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
.. exception:: error
|
|
|
|
|
2008-11-25 15:19:17 -04:00
|
|
|
Raised on :mod:`dbm.ndbm`-specific errors, such as I/O errors. :exc:`KeyError` is raised
|
2008-05-26 07:29:35 -03:00
|
|
|
for general mapping errors like specifying an incorrect key.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
.. data:: library
|
|
|
|
|
|
|
|
Name of the ``ndbm`` implementation library used.
|
|
|
|
|
|
|
|
|
|
|
|
.. function:: open(filename[, flag[, mode]])
|
|
|
|
|
2008-11-25 15:19:17 -04:00
|
|
|
Open a dbm database and return a ``dbm`` object. The *filename* argument is the
|
2010-08-01 18:03:01 -03:00
|
|
|
name of the database file (without the :file:`.dir` or :file:`.pag` extensions).
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
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
|
2008-05-26 14:55:52 -03:00
|
|
|
database has to be created. It defaults to octal ``0o666`` (and will be
|
2007-08-15 11:28:22 -03:00
|
|
|
modified by the prevailing umask).
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-05-26 07:29:35 -03:00
|
|
|
: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
|
2008-11-25 15:19:17 -04:00
|
|
|
:mod:`dbm` module when a more robust module is not available. The :mod:`dbm.dumb`
|
2008-05-26 07:29:35 -03:00
|
|
|
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
|
2008-11-25 15:19:17 -04:00
|
|
|
is written entirely in Python. Unlike other modules such as :mod:`dbm.gnu` no
|
2008-09-07 23:49:30 -03:00
|
|
|
external library is required. As with other persistent mappings, the keys and
|
2008-11-25 15:19:17 -04:00
|
|
|
values are always stored as bytes.
|
2008-05-26 07:29:35 -03:00
|
|
|
|
|
|
|
The module defines the following:
|
|
|
|
|
|
|
|
|
|
|
|
.. exception:: error
|
|
|
|
|
2008-11-25 15:19:17 -04:00
|
|
|
Raised on :mod:`dbm.dumb`-specific errors, such as I/O errors. :exc:`KeyError` is
|
2008-05-26 07:29:35 -03:00
|
|
|
raised for general mapping errors like specifying an incorrect key.
|
|
|
|
|
|
|
|
|
|
|
|
.. function:: open(filename[, flag[, mode]])
|
|
|
|
|
2008-11-25 15:19:17 -04:00
|
|
|
Open a ``dumbdbm`` database and return a dumbdbm object. The *filename* argument is
|
2008-05-26 07:29:35 -03:00
|
|
|
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).
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2008-05-26 07:29:35 -03:00
|
|
|
In addition to the methods provided by the :class:`collections.MutableMapping` class,
|
|
|
|
:class:`dumbdbm` objects provide the following method:
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2008-05-26 07:29:35 -03:00
|
|
|
.. method:: dumbdbm.sync()
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2008-05-26 07:29:35 -03:00
|
|
|
Synchronize the on-disk directory and data files. This method is called
|
|
|
|
by the :meth:`Shelve.sync` method.
|