Home | History | Annotate | Download | only in library
      1 :mod:`ConfigParser` --- Configuration file parser
      2 =================================================
      3 
      4 .. module:: ConfigParser
      5    :synopsis: Configuration file parser.
      6 
      7 .. moduleauthor:: Ken Manheimer <klm (a] zope.com>
      8 .. moduleauthor:: Barry Warsaw <bwarsaw (a] python.org>
      9 .. moduleauthor:: Eric S. Raymond <esr (a] thyrsus.com>
     10 .. sectionauthor:: Christopher G. Petrilli <petrilli (a] amber.org>
     11 
     12 .. note::
     13 
     14    The :mod:`ConfigParser` module has been renamed to :mod:`configparser` in
     15    Python 3.  The :term:`2to3` tool will automatically adapt imports when
     16    converting your sources to Python 3.
     17 
     18 .. index::
     19    pair: .ini; file
     20    pair: configuration; file
     21    single: ini file
     22    single: Windows ini file
     23 
     24 This module defines the class :class:`~ConfigParser.ConfigParser`.   The :class:`~ConfigParser.ConfigParser`
     25 class implements a basic configuration file parser language which provides a
     26 structure similar to what you would find on Microsoft Windows INI files.  You
     27 can use this to write Python programs which can be customized by end users
     28 easily.
     29 
     30 .. note::
     31 
     32    This library does *not* interpret or write the value-type prefixes used in
     33    the Windows Registry extended version of INI syntax.
     34 
     35 .. seealso::
     36 
     37    Module :mod:`shlex`
     38       Support for creating Unix shell-like mini-languages which can be used as
     39       an alternate format for application configuration files.
     40 
     41    Module :mod:`json`
     42       The json module implements a subset of JavaScript syntax which can also
     43       be used for this purpose.
     44 
     45 The configuration file consists of sections, led by a ``[section]`` header and
     46 followed by ``name: value`` entries, with continuations in the style of
     47 :rfc:`822` (see section 3.1.1, "LONG HEADER FIELDS"); ``name=value`` is also
     48 accepted.  Note that leading whitespace is removed from values. The optional
     49 values can contain format strings which refer to other values in the same
     50 section, or values in a special ``DEFAULT`` section.  Additional defaults can be
     51 provided on initialization and retrieval.  Lines beginning with ``'#'`` or
     52 ``';'`` are ignored and may be used to provide comments.
     53 
     54 Configuration files may include comments, prefixed by specific characters (``#``
     55 and ``;``).  Comments may appear on their own in an otherwise empty line, or may
     56 be entered in lines holding values or section names.  In the latter case, they
     57 need to be preceded by a whitespace character to be recognized as a comment.
     58 (For backwards compatibility, only ``;`` starts an inline comment, while ``#``
     59 does not.)
     60 
     61 On top of the core functionality, :class:`SafeConfigParser` supports
     62 interpolation.  This means values can contain format strings which refer to
     63 other values in the same section, or values in a special ``DEFAULT`` section.
     64 Additional defaults can be provided on initialization.
     65 
     66 For example::
     67 
     68    [My Section]
     69    foodir: %(dir)s/whatever
     70    dir=frob
     71    long: this value continues
     72       in the next line
     73 
     74 would resolve the ``%(dir)s`` to the value of ``dir`` (``frob`` in this case).
     75 All reference expansions are done on demand.
     76 
     77 Default values can be specified by passing them into the :class:`~ConfigParser.ConfigParser`
     78 constructor as a dictionary.  Additional defaults  may be passed into the
     79 :meth:`get` method which will override all others.
     80 
     81 Sections are normally stored in a built-in dictionary. An alternative dictionary
     82 type can be passed to the :class:`~ConfigParser.ConfigParser` constructor. For example, if a
     83 dictionary type is passed that sorts its keys, the sections will be sorted on
     84 write-back, as will be the keys within each section.
     85 
     86 
     87 .. class:: RawConfigParser([defaults[, dict_type[, allow_no_value]]])
     88 
     89    The basic configuration object.  When *defaults* is given, it is initialized
     90    into the dictionary of intrinsic defaults.  When *dict_type* is given, it will
     91    be used to create the dictionary objects for the list of sections, for the
     92    options within a section, and for the default values.  When *allow_no_value*
     93    is true (default: ``False``), options without values are accepted; the value
     94    presented for these is ``None``.
     95 
     96    This class does not
     97    support the magical interpolation behavior.
     98 
     99    All option names are passed through the :meth:`optionxform` method.  Its
    100    default implementation converts option names to lower case.
    101 
    102    .. versionadded:: 2.3
    103 
    104    .. versionchanged:: 2.6
    105       *dict_type* was added.
    106 
    107    .. versionchanged:: 2.7
    108       The default *dict_type* is :class:`collections.OrderedDict`.
    109       *allow_no_value* was added.
    110 
    111 
    112 .. class:: ConfigParser([defaults[, dict_type[, allow_no_value]]])
    113 
    114    Derived class of :class:`RawConfigParser` that implements the magical
    115    interpolation feature and adds optional arguments to the :meth:`get` and
    116    :meth:`items` methods.  The values in *defaults* must be appropriate for the
    117    ``%()s`` string interpolation.  Note that *__name__* is an intrinsic default;
    118    its value is the section name, and will override any value provided in
    119    *defaults*.
    120 
    121    All option names used in interpolation will be passed through the
    122    :meth:`optionxform` method just like any other option name reference.  Using
    123    the default implementation of :meth:`optionxform`, the values ``foo %(bar)s``
    124    and ``foo %(BAR)s`` are equivalent.
    125 
    126    .. versionadded:: 2.3
    127 
    128    .. versionchanged:: 2.6
    129       *dict_type* was added.
    130 
    131    .. versionchanged:: 2.7
    132       The default *dict_type* is :class:`collections.OrderedDict`.
    133       *allow_no_value* was added.
    134 
    135 
    136 .. class:: SafeConfigParser([defaults[, dict_type[, allow_no_value]]])
    137 
    138    Derived class of :class:`~ConfigParser.ConfigParser` that implements a more-sane variant of
    139    the magical interpolation feature.  This implementation is more predictable as
    140    well. New applications should prefer this version if they don't need to be
    141    compatible with older versions of Python.
    142 
    143    .. XXX Need to explain what's safer/more predictable about it.
    144 
    145    .. versionadded:: 2.3
    146 
    147    .. versionchanged:: 2.6
    148       *dict_type* was added.
    149 
    150    .. versionchanged:: 2.7
    151       The default *dict_type* is :class:`collections.OrderedDict`.
    152       *allow_no_value* was added.
    153 
    154 
    155 .. exception:: Error
    156 
    157    Base class for all other configparser exceptions.
    158 
    159 
    160 .. exception:: NoSectionError
    161 
    162    Exception raised when a specified section is not found.
    163 
    164 
    165 .. exception:: DuplicateSectionError
    166 
    167    Exception raised if :meth:`add_section` is called with the name of a section
    168    that is already present.
    169 
    170 
    171 .. exception:: NoOptionError
    172 
    173    Exception raised when a specified option is not found in the specified  section.
    174 
    175 
    176 .. exception:: InterpolationError
    177 
    178    Base class for exceptions raised when problems occur performing string
    179    interpolation.
    180 
    181 
    182 .. exception:: InterpolationDepthError
    183 
    184    Exception raised when string interpolation cannot be completed because the
    185    number of iterations exceeds :const:`MAX_INTERPOLATION_DEPTH`. Subclass of
    186    :exc:`InterpolationError`.
    187 
    188 
    189 .. exception:: InterpolationMissingOptionError
    190 
    191    Exception raised when an option referenced from a value does not exist. Subclass
    192    of :exc:`InterpolationError`.
    193 
    194    .. versionadded:: 2.3
    195 
    196 
    197 .. exception:: InterpolationSyntaxError
    198 
    199    Exception raised when the source text into which substitutions are made does not
    200    conform to the required syntax. Subclass of :exc:`InterpolationError`.
    201 
    202    .. versionadded:: 2.3
    203 
    204 
    205 .. exception:: MissingSectionHeaderError
    206 
    207    Exception raised when attempting to parse a file which has no section headers.
    208 
    209 
    210 .. exception:: ParsingError
    211 
    212    Exception raised when errors occur attempting to parse a file.
    213 
    214 
    215 .. data:: MAX_INTERPOLATION_DEPTH
    216 
    217    The maximum depth for recursive interpolation for :meth:`get` when the *raw*
    218    parameter is false.  This is relevant only for the :class:`~ConfigParser.ConfigParser` class.
    219 
    220 
    221 .. seealso::
    222 
    223    Module :mod:`shlex`
    224       Support for a creating Unix shell-like mini-languages which can be used as an
    225       alternate format for application configuration files.
    226 
    227 
    228 .. _rawconfigparser-objects:
    229 
    230 RawConfigParser Objects
    231 -----------------------
    232 
    233 :class:`RawConfigParser` instances have the following methods:
    234 
    235 
    236 .. method:: RawConfigParser.defaults()
    237 
    238    Return a dictionary containing the instance-wide defaults.
    239 
    240 
    241 .. method:: RawConfigParser.sections()
    242 
    243    Return a list of the sections available; ``DEFAULT`` is not included in the
    244    list.
    245 
    246 
    247 .. method:: RawConfigParser.add_section(section)
    248 
    249    Add a section named *section* to the instance.  If a section by the given name
    250    already exists, :exc:`DuplicateSectionError` is raised. If the name
    251    ``DEFAULT`` (or any of it's case-insensitive variants) is passed,
    252    :exc:`ValueError` is raised.
    253 
    254 .. method:: RawConfigParser.has_section(section)
    255 
    256    Indicates whether the named section is present in the configuration. The
    257    ``DEFAULT`` section is not acknowledged.
    258 
    259 
    260 .. method:: RawConfigParser.options(section)
    261 
    262    Returns a list of options available in the specified *section*.
    263 
    264 
    265 .. method:: RawConfigParser.has_option(section, option)
    266 
    267    If the given section exists, and contains the given option, return
    268    :const:`True`; otherwise return :const:`False`.
    269 
    270    .. versionadded:: 1.6
    271 
    272 
    273 .. method:: RawConfigParser.read(filenames)
    274 
    275    Attempt to read and parse a list of filenames, returning a list of filenames
    276    which were successfully parsed.  If *filenames* is a string or Unicode string,
    277    it is treated as a single filename. If a file named in *filenames* cannot be
    278    opened, that file will be ignored.  This is designed so that you can specify a
    279    list of potential configuration file locations (for example, the current
    280    directory, the user's home directory, and some system-wide directory), and all
    281    existing configuration files in the list will be read.  If none of the named
    282    files exist, the :class:`~ConfigParser.ConfigParser` instance will contain an empty dataset.
    283    An application which requires initial values to be loaded from a file should
    284    load the required file or files using :meth:`readfp` before calling :meth:`read`
    285    for any optional files::
    286 
    287       import ConfigParser, os
    288 
    289       config = ConfigParser.ConfigParser()
    290       config.readfp(open('defaults.cfg'))
    291       config.read(['site.cfg', os.path.expanduser('~/.myapp.cfg')])
    292 
    293    .. versionchanged:: 2.4
    294       Returns list of successfully parsed filenames.
    295 
    296 
    297 .. method:: RawConfigParser.readfp(fp[, filename])
    298 
    299    Read and parse configuration data from the file or file-like object in *fp*
    300    (only the :meth:`readline` method is used).  If *filename* is omitted and *fp*
    301    has a :attr:`name` attribute, that is used for *filename*; the default is
    302    ``<???>``.
    303 
    304 
    305 .. method:: RawConfigParser.get(section, option)
    306 
    307    Get an *option* value for the named *section*.
    308 
    309 
    310 .. method:: RawConfigParser.getint(section, option)
    311 
    312    A convenience method which coerces the *option* in the specified *section* to an
    313    integer.
    314 
    315 
    316 .. method:: RawConfigParser.getfloat(section, option)
    317 
    318    A convenience method which coerces the *option* in the specified *section* to a
    319    floating point number.
    320 
    321 
    322 .. method:: RawConfigParser.getboolean(section, option)
    323 
    324    A convenience method which coerces the *option* in the specified *section* to a
    325    Boolean value.  Note that the accepted values for the option are ``"1"``,
    326    ``"yes"``, ``"true"``, and ``"on"``, which cause this method to return ``True``,
    327    and ``"0"``, ``"no"``, ``"false"``, and ``"off"``, which cause it to return
    328    ``False``.  These string values are checked in a case-insensitive manner.  Any
    329    other value will cause it to raise :exc:`ValueError`.
    330 
    331 
    332 .. method:: RawConfigParser.items(section)
    333 
    334    Return a list of ``(name, value)`` pairs for each option in the given *section*.
    335 
    336 
    337 .. method:: RawConfigParser.set(section, option, value)
    338 
    339    If the given section exists, set the given option to the specified value;
    340    otherwise raise :exc:`NoSectionError`.  While it is possible to use
    341    :class:`RawConfigParser` (or :class:`~ConfigParser.ConfigParser` with *raw* parameters set to
    342    true) for *internal* storage of non-string values, full functionality (including
    343    interpolation and output to files) can only be achieved using string values.
    344 
    345    .. versionadded:: 1.6
    346 
    347 
    348 .. method:: RawConfigParser.write(fileobject)
    349 
    350    Write a representation of the configuration to the specified file object.  This
    351    representation can be parsed by a future :meth:`read` call.
    352 
    353    .. versionadded:: 1.6
    354 
    355 
    356 .. method:: RawConfigParser.remove_option(section, option)
    357 
    358    Remove the specified *option* from the specified *section*. If the section does
    359    not exist, raise :exc:`NoSectionError`.  If the option existed to be removed,
    360    return :const:`True`; otherwise return :const:`False`.
    361 
    362    .. versionadded:: 1.6
    363 
    364 
    365 .. method:: RawConfigParser.remove_section(section)
    366 
    367    Remove the specified *section* from the configuration. If the section in fact
    368    existed, return ``True``. Otherwise return ``False``.
    369 
    370 
    371 .. method:: RawConfigParser.optionxform(option)
    372 
    373    Transforms the option name *option* as found in an input file or as passed in
    374    by client code to the form that should be used in the internal structures.
    375    The default implementation returns a lower-case version of *option*;
    376    subclasses may override this or client code can set an attribute of this name
    377    on instances to affect this behavior.
    378 
    379    You don't necessarily need to subclass a ConfigParser to use this method, you
    380    can also re-set it on an instance, to a function that takes a string
    381    argument.  Setting it to ``str``, for example, would make option names case
    382    sensitive::
    383 
    384       cfgparser = ConfigParser()
    385       ...
    386       cfgparser.optionxform = str
    387 
    388    Note that when reading configuration files, whitespace around the
    389    option names are stripped before :meth:`optionxform` is called.
    390 
    391 
    392 .. _configparser-objects:
    393 
    394 ConfigParser Objects
    395 --------------------
    396 
    397 The :class:`~ConfigParser.ConfigParser` class extends some methods of the
    398 :class:`RawConfigParser` interface, adding some optional arguments.
    399 
    400 
    401 .. method:: ConfigParser.get(section, option[, raw[, vars]])
    402 
    403    Get an *option* value for the named *section*.  If *vars* is provided, it
    404    must be a dictionary.  The *option* is looked up in *vars* (if provided),
    405    *section*, and in *defaults* in that order.
    406 
    407    All the ``'%'`` interpolations are expanded in the return values, unless the
    408    *raw* argument is true.  Values for interpolation keys are looked up in the
    409    same manner as the option.
    410 
    411 .. method:: ConfigParser.items(section[, raw[, vars]])
    412 
    413    Return a list of ``(name, value)`` pairs for each option in the given *section*.
    414    Optional arguments have the same meaning as for the :meth:`get` method.
    415 
    416    .. versionadded:: 2.3
    417 
    418 
    419 .. _safeconfigparser-objects:
    420 
    421 SafeConfigParser Objects
    422 ------------------------
    423 
    424 The :class:`SafeConfigParser` class implements the same extended interface as
    425 :class:`~ConfigParser.ConfigParser`, with the following addition:
    426 
    427 
    428 .. method:: SafeConfigParser.set(section, option, value)
    429 
    430    If the given section exists, set the given option to the specified value;
    431    otherwise raise :exc:`NoSectionError`.  *value* must be a string (:class:`str`
    432    or :class:`unicode`); if not, :exc:`TypeError` is raised.
    433 
    434    .. versionadded:: 2.4
    435 
    436 
    437 Examples
    438 --------
    439 
    440 An example of writing to a configuration file::
    441 
    442    import ConfigParser
    443 
    444    config = ConfigParser.RawConfigParser()
    445 
    446    # When adding sections or items, add them in the reverse order of
    447    # how you want them to be displayed in the actual file.
    448    # In addition, please note that using RawConfigParser's and the raw
    449    # mode of ConfigParser's respective set functions, you can assign
    450    # non-string values to keys internally, but will receive an error
    451    # when attempting to write to a file or when you get it in non-raw
    452    # mode. SafeConfigParser does not allow such assignments to take place.
    453    config.add_section('Section1')
    454    config.set('Section1', 'an_int', '15')
    455    config.set('Section1', 'a_bool', 'true')
    456    config.set('Section1', 'a_float', '3.1415')
    457    config.set('Section1', 'baz', 'fun')
    458    config.set('Section1', 'bar', 'Python')
    459    config.set('Section1', 'foo', '%(bar)s is %(baz)s!')
    460 
    461    # Writing our configuration file to 'example.cfg'
    462    with open('example.cfg', 'wb') as configfile:
    463        config.write(configfile)
    464 
    465 An example of reading the configuration file again::
    466 
    467    import ConfigParser
    468 
    469    config = ConfigParser.RawConfigParser()
    470    config.read('example.cfg')
    471 
    472    # getfloat() raises an exception if the value is not a float
    473    # getint() and getboolean() also do this for their respective types
    474    a_float = config.getfloat('Section1', 'a_float')
    475    an_int = config.getint('Section1', 'an_int')
    476    print a_float + an_int
    477 
    478    # Notice that the next output does not interpolate '%(bar)s' or '%(baz)s'.
    479    # This is because we are using a RawConfigParser().
    480    if config.getboolean('Section1', 'a_bool'):
    481        print config.get('Section1', 'foo')
    482 
    483 To get interpolation, you will need to use a :class:`~ConfigParser.ConfigParser` or
    484 :class:`SafeConfigParser`::
    485 
    486    import ConfigParser
    487 
    488    config = ConfigParser.ConfigParser()
    489    config.read('example.cfg')
    490 
    491    # Set the third, optional argument of get to 1 if you wish to use raw mode.
    492    print config.get('Section1', 'foo', 0)  # -> "Python is fun!"
    493    print config.get('Section1', 'foo', 1)  # -> "%(bar)s is %(baz)s!"
    494 
    495    # The optional fourth argument is a dict with members that will take
    496    # precedence in interpolation.
    497    print config.get('Section1', 'foo', 0, {'bar': 'Documentation',
    498                                            'baz': 'evil'})
    499 
    500 Defaults are available in all three types of ConfigParsers. They are used in
    501 interpolation if an option used is not defined elsewhere. ::
    502 
    503    import ConfigParser
    504 
    505    # New instance with 'bar' and 'baz' defaulting to 'Life' and 'hard' each
    506    config = ConfigParser.SafeConfigParser({'bar': 'Life', 'baz': 'hard'})
    507    config.read('example.cfg')
    508 
    509    print config.get('Section1', 'foo')  # -> "Python is fun!"
    510    config.remove_option('Section1', 'bar')
    511    config.remove_option('Section1', 'baz')
    512    print config.get('Section1', 'foo')  # -> "Life is hard!"
    513 
    514 The function ``opt_move`` below can be used to move options between sections::
    515 
    516    def opt_move(config, section1, section2, option):
    517        try:
    518            config.set(section2, option, config.get(section1, option, 1))
    519        except ConfigParser.NoSectionError:
    520            # Create non-existent section
    521            config.add_section(section2)
    522            opt_move(config, section1, section2, option)
    523        else:
    524            config.remove_option(section1, option)
    525 
    526 Some configuration files are known to include settings without values, but which
    527 otherwise conform to the syntax supported by :mod:`ConfigParser`.  The
    528 *allow_no_value* parameter to the constructor can be used to indicate that such
    529 values should be accepted:
    530 
    531 .. doctest::
    532 
    533    >>> import ConfigParser
    534    >>> import io
    535 
    536    >>> sample_config = """
    537    ... [mysqld]
    538    ... user = mysql
    539    ... pid-file = /var/run/mysqld/mysqld.pid
    540    ... skip-external-locking
    541    ... old_passwords = 1
    542    ... skip-bdb
    543    ... skip-innodb
    544    ... """
    545    >>> config = ConfigParser.RawConfigParser(allow_no_value=True)
    546    >>> config.readfp(io.BytesIO(sample_config))
    547 
    548    >>> # Settings with values are treated as before:
    549    >>> config.get("mysqld", "user")
    550    'mysql'
    551 
    552    >>> # Settings without values provide None:
    553    >>> config.get("mysqld", "skip-bdb")
    554 
    555    >>> # Settings which aren't specified still raise an error:
    556    >>> config.get("mysqld", "does-not-exist")
    557    Traceback (most recent call last):
    558      ...
    559    ConfigParser.NoOptionError: No option 'does-not-exist' in section: 'mysqld'
    560