mirror of
				https://github.com/python/cpython.git
				synced 2025-11-04 07:31:38 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			61 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			TeX
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			TeX
		
	
	
	
	
	
\section{\module{dbm} ---
 | 
						|
         Simple ``database'' interface}
 | 
						|
 | 
						|
\declaremodule{builtin}{dbm}
 | 
						|
  \platform{Unix}
 | 
						|
\modulesynopsis{The standard ``database'' interface, based on ndbm.}
 | 
						|
 | 
						|
 | 
						|
The \module{dbm} module provides an interface to the \UNIX{}
 | 
						|
(\code{n})\code{dbm} library.  Dbm objects behave like mappings
 | 
						|
(dictionaries), except that keys and values are always strings.
 | 
						|
Printing a dbm object doesn't print the keys and values, and the
 | 
						|
\method{items()} and \method{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.
 | 
						|
 | 
						|
The module defines the following:
 | 
						|
 | 
						|
\begin{excdesc}{error}
 | 
						|
Raised on dbm-specific errors, such as I/O errors.
 | 
						|
\exception{KeyError} is raised for general mapping errors like
 | 
						|
specifying an incorrect key.
 | 
						|
\end{excdesc}
 | 
						|
 | 
						|
\begin{datadesc}{library}
 | 
						|
Name of the \code{ndbm} implementation library used.
 | 
						|
\end{datadesc}
 | 
						|
 | 
						|
\begin{funcdesc}{open}{filename\optional{, flag\optional{, mode}}}
 | 
						|
Open a dbm database and return a dbm object.  The \var{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 \var{flag} argument must be one of these values:
 | 
						|
 | 
						|
\begin{tableii}{c|l}{code}{Value}{Meaning}
 | 
						|
  \lineii{'r'}{Open existing database for reading only (default)}
 | 
						|
  \lineii{'w'}{Open existing database for reading and writing}
 | 
						|
  \lineii{'c'}{Open database for reading and writing, creating it if
 | 
						|
               it doesn't exist}
 | 
						|
  \lineii{'n'}{Always create a new, empty database, open for reading
 | 
						|
               and writing}
 | 
						|
\end{tableii}
 | 
						|
 | 
						|
The optional \var{mode} argument is the \UNIX{} mode of the file, used
 | 
						|
only when the database has to be created.  It defaults to octal
 | 
						|
\code{0666}.
 | 
						|
\end{funcdesc}
 | 
						|
 | 
						|
 | 
						|
\begin{seealso}
 | 
						|
  \seemodule{anydbm}{Generic interface to \code{dbm}-style databases.}
 | 
						|
  \seemodule{gdbm}{Similar interface to the GNU GDBM library.}
 | 
						|
  \seemodule{whichdb}{Utility module used to determine the type of an
 | 
						|
                      existing database.}
 | 
						|
\end{seealso}
 |