1999-01-26 11:47:59 -04:00
|
|
|
\section{\module{ConfigParser} ---
|
1999-04-21 13:41:40 -03:00
|
|
|
Configuration file parser}
|
1999-01-26 11:47:59 -04:00
|
|
|
|
|
|
|
\declaremodule{standard}{ConfigParser}
|
|
|
|
\modulesynopsis{Configuration file parser.}
|
2000-04-03 17:13:55 -03:00
|
|
|
\moduleauthor{Ken Manheimer}{klm@digicool.com}
|
|
|
|
\moduleauthor{Barry Warsaw}{bwarsaw@python.org}
|
1999-01-26 11:47:59 -04:00
|
|
|
\sectionauthor{Christopher G. Petrilli}{petrilli@amber.org}
|
|
|
|
|
1999-06-15 14:30:59 -03:00
|
|
|
This module defines the class \class{ConfigParser}.
|
|
|
|
\indexii{.ini}{file}\indexii{configuration}{file}\index{ini file}
|
|
|
|
\index{Windows ini file}
|
|
|
|
The \class{ConfigParser} class implements a basic configuration file
|
1999-01-26 11:47:59 -04:00
|
|
|
parser language which provides a structure similar to what you would
|
1999-06-15 14:30:59 -03:00
|
|
|
find on Microsoft Windows INI files. You can use this to write Python
|
1999-01-26 11:47:59 -04:00
|
|
|
programs which can be customized by end users easily.
|
|
|
|
|
|
|
|
The configuration file consists of sections, lead by a
|
|
|
|
\samp{[section]} header and followed by \samp{name: value} entries,
|
1999-06-15 14:30:59 -03:00
|
|
|
with continuations in the style of \rfc{822}; \samp{name=value} is
|
2000-04-03 17:13:55 -03:00
|
|
|
also accepted. Note that leading whitespace is removed from values.
|
|
|
|
The optional values can contain format strings which refer to other
|
|
|
|
values in the same section, or values in a special
|
1999-06-15 14:30:59 -03:00
|
|
|
\code{DEFAULT} section. Additional defaults can be provided upon
|
2000-04-03 17:13:55 -03:00
|
|
|
initialization and retrieval. Lines beginning with \character{\#} or
|
|
|
|
\character{;} are ignored and may be used to provide comments.
|
1999-01-26 11:47:59 -04:00
|
|
|
|
|
|
|
For example:
|
|
|
|
|
|
|
|
\begin{verbatim}
|
|
|
|
foodir: %(dir)s/whatever
|
2000-04-03 17:13:55 -03:00
|
|
|
dir=frob
|
1999-01-26 11:47:59 -04:00
|
|
|
\end{verbatim}
|
|
|
|
|
2000-04-03 17:13:55 -03:00
|
|
|
would resolve the \samp{\%(dir)s} to the value of
|
|
|
|
\samp{dir} (\samp{frob} in this case). All reference expansions are
|
|
|
|
done on demand.
|
1999-01-26 11:47:59 -04:00
|
|
|
|
2000-04-03 17:13:55 -03:00
|
|
|
Default values can be specified by passing them into the
|
|
|
|
\class{ConfigParser} constructor as a dictionary. Additional defaults
|
|
|
|
may be passed into the \method{get()} method which will override all
|
1999-01-26 17:49:05 -04:00
|
|
|
others.
|
1999-01-26 11:47:59 -04:00
|
|
|
|
|
|
|
\begin{classdesc}{ConfigParser}{\optional{defaults}}
|
|
|
|
Return a new instance of the \class{ConfigParser} class. When
|
|
|
|
\var{defaults} is given, it is initialized into the dictionairy of
|
|
|
|
intrinsic defaults. They keys must be strings, and the values must be
|
|
|
|
appropriate for the \samp{\%()s} string interpolation. Note that
|
1999-05-11 12:14:15 -03:00
|
|
|
\var{__name__} is always an intrinsic default; its value is the
|
1999-01-26 11:47:59 -04:00
|
|
|
section name.
|
|
|
|
\end{classdesc}
|
|
|
|
|
|
|
|
\begin{excdesc}{NoSectionError}
|
|
|
|
Exception raised when a specified section is not found.
|
|
|
|
\end{excdesc}
|
|
|
|
|
|
|
|
\begin{excdesc}{DuplicateSectionError}
|
2000-04-03 17:13:55 -03:00
|
|
|
Exception raised when mutliple sections with the same name are found,
|
|
|
|
or if \method{add_section()} is called with the name of a section that
|
|
|
|
is already present.
|
1999-01-26 11:47:59 -04:00
|
|
|
\end{excdesc}
|
|
|
|
|
|
|
|
\begin{excdesc}{NoOptionError}
|
|
|
|
Exception raised when a specified option is not found in the specified
|
|
|
|
section.
|
|
|
|
\end{excdesc}
|
|
|
|
|
|
|
|
\begin{excdesc}{InterpolationError}
|
|
|
|
Exception raised when problems occur performing string interpolation.
|
|
|
|
\end{excdesc}
|
|
|
|
|
|
|
|
\begin{excdesc}{MissingSectionHeaderError}
|
|
|
|
Exception raised when attempting to parse a file which has no section
|
|
|
|
headers.
|
|
|
|
\end{excdesc}
|
|
|
|
|
|
|
|
\begin{excdesc}{ParsingError}
|
|
|
|
Exception raised when errors occur attempting to parse a file.
|
|
|
|
\end{excdesc}
|
|
|
|
|
1999-01-26 17:49:05 -04:00
|
|
|
|
1999-05-11 12:14:15 -03:00
|
|
|
\begin{seealso}
|
|
|
|
\seemodule{shlex}{Support for a creating \UNIX{} shell-like
|
|
|
|
minilanguages which can be used as an alternate format
|
|
|
|
for application configuration files.}
|
|
|
|
\end{seealso}
|
|
|
|
|
1999-01-26 11:47:59 -04:00
|
|
|
\subsection{ConfigParser Objects \label{ConfigParser-objects}}
|
|
|
|
|
|
|
|
\class{ConfigParser} instances have the following methods:
|
|
|
|
|
|
|
|
\begin{methoddesc}{defaults}{}
|
|
|
|
Return a dictionairy containing the instance-wide defaults.
|
|
|
|
\end{methoddesc}
|
|
|
|
|
|
|
|
\begin{methoddesc}{sections}{}
|
2000-04-03 17:13:55 -03:00
|
|
|
Return a list of the sections available; \code{DEFAULT} is not
|
|
|
|
included in the list.
|
|
|
|
\end{methoddesc}
|
|
|
|
|
|
|
|
\begin{methoddesc}{add_section}{section}
|
|
|
|
Add a section named \var{section} to the instance. If a section by
|
|
|
|
the given name already exists, \exception{DuplicateSectionError} is
|
|
|
|
raised.
|
1999-01-26 11:47:59 -04:00
|
|
|
\end{methoddesc}
|
|
|
|
|
|
|
|
\begin{methoddesc}{has_section}{section}
|
|
|
|
Indicates whether the named section is present in the
|
|
|
|
configuration. The \code{DEFAULT} section is not acknowledged.
|
|
|
|
\end{methoddesc}
|
|
|
|
|
|
|
|
\begin{methoddesc}{options}{section}
|
|
|
|
Returns a list of options available in the specified \var{section}.
|
|
|
|
\end{methoddesc}
|
|
|
|
|
|
|
|
\begin{methoddesc}{read}{filenames}
|
|
|
|
Read and parse a list of filenames.
|
|
|
|
\end{methoddesc}
|
|
|
|
|
1999-01-26 17:49:05 -04:00
|
|
|
\begin{methoddesc}{get}{section, option\optional{, raw\optional{, vars}}}
|
1999-01-26 11:47:59 -04:00
|
|
|
Get an \var{option} value for the provided \var{section}. All the
|
1999-04-21 13:41:40 -03:00
|
|
|
\character{\%} interpolations are expanded in the return values, based on
|
1999-01-26 17:49:05 -04:00
|
|
|
the defaults passed into the constructor, as well as the options
|
|
|
|
\var{vars} provided, unless the \var{raw} argument is true.
|
1999-01-26 11:47:59 -04:00
|
|
|
\end{methoddesc}
|
|
|
|
|
|
|
|
\begin{methoddesc}{getint}{section, option}
|
|
|
|
A convenience method which coerces the \var{option} in the specified
|
|
|
|
\var{section} to an integer.
|
|
|
|
\end{methoddesc}
|
|
|
|
|
|
|
|
\begin{methoddesc}{getfloat}{section, option}
|
|
|
|
A convenience method which coerces the \var{option} in the specified
|
|
|
|
\var{section} to a floating point number.
|
|
|
|
\end{methoddesc}
|
|
|
|
|
|
|
|
\begin{methoddesc}{getboolean}{section, option}
|
|
|
|
A convenience method which coerces the \var{option} in the specified
|
|
|
|
\var{section} to a boolean value. Note that the only accepted values
|
2000-04-03 17:13:55 -03:00
|
|
|
for the option are \samp{0} and \samp{1}, any others will raise
|
1999-01-26 11:47:59 -04:00
|
|
|
\exception{ValueError}.
|
|
|
|
\end{methoddesc}
|