| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | :mod:`mimetypes` --- Map filenames to MIME types
 | 
					
						
							|  |  |  | ================================================
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. module:: mimetypes
 | 
					
						
							|  |  |  |    :synopsis: Mapping of filename extensions to MIME types.
 | 
					
						
							|  |  |  | .. sectionauthor:: Fred L. Drake, Jr. <fdrake@acm.org>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. index:: pair: MIME; content type
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-27 20:38:46 +00:00
										 |  |  | **Source code:** :source:`Lib/mimetypes.py`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | --------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | The :mod:`mimetypes` module converts between a filename or URL and the MIME type
 | 
					
						
							|  |  |  | associated with the filename extension.  Conversions are provided from filename
 | 
					
						
							|  |  |  | to MIME type and from MIME type to filename extension; encodings are not
 | 
					
						
							|  |  |  | supported for the latter conversion.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The module provides one class and a number of convenience functions. The
 | 
					
						
							|  |  |  | functions are the normal interface to this module, but some applications may be
 | 
					
						
							|  |  |  | interested in the class as well.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The functions described below provide the primary interface for this module.  If
 | 
					
						
							|  |  |  | the module has not been initialized, they will call :func:`init` if they rely on
 | 
					
						
							|  |  |  | the information :func:`init` sets up.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-08 09:13:45 +00:00
										 |  |  | .. function:: guess_type(url, strict=True)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    .. index:: pair: MIME; headers
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    Guess the type of a file based on its filename or URL, given by *url*.  The
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    return value is a tuple ``(type, encoding)`` where *type* is ``None`` if the
 | 
					
						
							|  |  |  |    type can't be guessed (missing or unknown suffix) or a string of the form
 | 
					
						
							|  |  |  |    ``'type/subtype'``, usable for a MIME :mailheader:`content-type` header.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    *encoding* is ``None`` for no encoding or the name of the program used to encode
 | 
					
						
							|  |  |  |    (e.g. :program:`compress` or :program:`gzip`). The encoding is suitable for use
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    as a :mailheader:`Content-Encoding` header, **not** as a
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    :mailheader:`Content-Transfer-Encoding` header. The mappings are table driven.
 | 
					
						
							|  |  |  |    Encoding suffixes are case sensitive; type suffixes are first tried case
 | 
					
						
							|  |  |  |    sensitively, then case insensitively.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    The optional *strict* argument is a flag specifying whether the list of known MIME types
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    is limited to only the official types `registered with IANA
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    <http://www.iana.org/assignments/media-types/>`_.
 | 
					
						
							|  |  |  |    When *strict* is ``True`` (the default), only the IANA types are supported; when
 | 
					
						
							|  |  |  |    *strict* is ``False``, some additional non-standard but commonly used MIME types
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    are also recognized.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-08 09:13:45 +00:00
										 |  |  | .. function:: guess_all_extensions(type, strict=True)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Guess the extensions for a file based on its MIME type, given by *type*. The
 | 
					
						
							|  |  |  |    return value is a list of strings giving all possible filename extensions,
 | 
					
						
							|  |  |  |    including the leading dot (``'.'``).  The extensions are not guaranteed to have
 | 
					
						
							|  |  |  |    been associated with any particular data stream, but would be mapped to the MIME
 | 
					
						
							|  |  |  |    type *type* by :func:`guess_type`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    The optional *strict* argument has the same meaning as with the :func:`guess_type` function.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-08 09:13:45 +00:00
										 |  |  | .. function:: guess_extension(type, strict=True)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Guess the extension for a file based on its MIME type, given by *type*. The
 | 
					
						
							|  |  |  |    return value is a string giving a filename extension, including the leading dot
 | 
					
						
							|  |  |  |    (``'.'``).  The extension is not guaranteed to have been associated with any
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    particular data stream, but would be mapped to the MIME type *type* by
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    :func:`guess_type`.  If no extension can be guessed for *type*, ``None`` is
 | 
					
						
							|  |  |  |    returned.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    The optional *strict* argument has the same meaning as with the :func:`guess_type` function.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | Some additional functions and data items are available for controlling the
 | 
					
						
							|  |  |  | behavior of the module.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-08 09:13:45 +00:00
										 |  |  | .. function:: init(files=None)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Initialize the internal data structures.  If given, *files* must be a sequence
 | 
					
						
							|  |  |  |    of file names which should be used to augment the default type map.  If omitted,
 | 
					
						
							| 
									
										
										
										
											2009-11-15 14:25:16 +00:00
										 |  |  |    the file names to use are taken from :const:`knownfiles`; on Windows, the
 | 
					
						
							|  |  |  |    current registry settings are loaded.  Each file named in *files* or
 | 
					
						
							|  |  |  |    :const:`knownfiles` takes precedence over those named before it.  Calling
 | 
					
						
							|  |  |  |    :func:`init` repeatedly is allowed.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionchanged:: 3.2
 | 
					
						
							|  |  |  |       Previously, Windows registry settings were ignored.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: read_mime_types(filename)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    Load the type map given in the file *filename*, if it exists.  The type map is
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    returned as a dictionary mapping filename extensions, including the leading dot
 | 
					
						
							|  |  |  |    (``'.'``), to strings of the form ``'type/subtype'``.  If the file *filename*
 | 
					
						
							|  |  |  |    does not exist or cannot be read, ``None`` is returned.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-08 09:13:45 +00:00
										 |  |  | .. function:: add_type(type, ext, strict=True)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    Add a mapping from the MIME type *type* to the extension *ext*. When the
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    extension is already known, the new type will replace the old one. When the type
 | 
					
						
							|  |  |  |    is already known the extension will be added to the list of known extensions.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    When *strict* is ``True`` (the default), the mapping will added to the official MIME
 | 
					
						
							| 
									
										
										
										
											2007-11-19 18:03:44 +00:00
										 |  |  |    types, otherwise to the non-standard ones.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. data:: inited
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Flag indicating whether or not the global data structures have been initialized.
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    This is set to ``True`` by :func:`init`.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. data:: knownfiles
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. index:: single: file; mime.types
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    List of type map file names commonly installed.  These files are typically named
 | 
					
						
							|  |  |  |    :file:`mime.types` and are installed in different locations by different
 | 
					
						
							|  |  |  |    packages.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. data:: suffix_map
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Dictionary mapping suffixes to suffixes.  This is used to allow recognition of
 | 
					
						
							|  |  |  |    encoded files for which the encoding and the type are indicated by the same
 | 
					
						
							|  |  |  |    extension.  For example, the :file:`.tgz` extension is mapped to :file:`.tar.gz`
 | 
					
						
							|  |  |  |    to allow the encoding and type to be recognized separately.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. data:: encodings_map
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Dictionary mapping filename extensions to encoding types.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. data:: types_map
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Dictionary mapping filename extensions to MIME types.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. data:: common_types
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Dictionary mapping filename extensions to non-standard, but commonly found MIME
 | 
					
						
							|  |  |  |    types.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | An example usage of the module::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    >>> import mimetypes
 | 
					
						
							|  |  |  |    >>> mimetypes.init()
 | 
					
						
							|  |  |  |    >>> mimetypes.knownfiles
 | 
					
						
							|  |  |  |    ['/etc/mime.types', '/etc/httpd/mime.types', ... ]
 | 
					
						
							|  |  |  |    >>> mimetypes.suffix_map['.tgz']
 | 
					
						
							|  |  |  |    '.tar.gz'
 | 
					
						
							|  |  |  |    >>> mimetypes.encodings_map['.gz']
 | 
					
						
							|  |  |  |    'gzip'
 | 
					
						
							|  |  |  |    >>> mimetypes.types_map['.tgz']
 | 
					
						
							|  |  |  |    'application/x-tar-gz'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. _mimetypes-objects:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | MimeTypes Objects
 | 
					
						
							|  |  |  | -----------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  | The :class:`MimeTypes` class may be useful for applications which may want more
 | 
					
						
							|  |  |  | than one MIME-type database; it provides an interface similar to the one of the
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | :mod:`mimetypes` module.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  | .. class:: MimeTypes(filenames=(), strict=True)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    This class represents a MIME-types database.  By default, it provides access to
 | 
					
						
							|  |  |  |    the same database as the rest of this module. The initial database is a copy of
 | 
					
						
							|  |  |  |    that provided by the module, and may be extended by loading additional
 | 
					
						
							|  |  |  |    :file:`mime.types`\ -style files into the database using the :meth:`read` or
 | 
					
						
							|  |  |  |    :meth:`readfp` methods.  The mapping dictionaries may also be cleared before
 | 
					
						
							|  |  |  |    loading additional data if the default data is not desired.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The optional *filenames* parameter can be used to cause additional files to be
 | 
					
						
							|  |  |  |    loaded "on top" of the default database.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | .. attribute:: MimeTypes.suffix_map
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Dictionary mapping suffixes to suffixes.  This is used to allow recognition of
 | 
					
						
							|  |  |  |    encoded files for which the encoding and the type are indicated by the same
 | 
					
						
							|  |  |  |    extension.  For example, the :file:`.tgz` extension is mapped to :file:`.tar.gz`
 | 
					
						
							|  |  |  |    to allow the encoding and type to be recognized separately.  This is initially a
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    copy of the global :data:`suffix_map` defined in the module.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. attribute:: MimeTypes.encodings_map
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Dictionary mapping filename extensions to encoding types.  This is initially a
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    copy of the global :data:`encodings_map` defined in the module.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. attribute:: MimeTypes.types_map
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    Tuple containing two dictionaries, mapping filename extensions to MIME types:
 | 
					
						
							|  |  |  |    the first dictionary is for the non-standards types and the second one is for
 | 
					
						
							|  |  |  |    the standard types. They are initialized by :data:`common_types` and
 | 
					
						
							|  |  |  |    :data:`types_map`.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  | .. attribute:: MimeTypes.types_map_inv
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    Tuple containing two dictionaries, mapping MIME types to a list of filename
 | 
					
						
							|  |  |  |    extensions: the first dictionary is for the non-standards types and the
 | 
					
						
							|  |  |  |    second one is for the standard types. They are initialized by
 | 
					
						
							|  |  |  |    :data:`common_types` and :data:`types_map`.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-08 09:13:45 +00:00
										 |  |  | .. method:: MimeTypes.guess_extension(type, strict=True)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Similar to the :func:`guess_extension` function, using the tables stored as part
 | 
					
						
							|  |  |  |    of the object.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-08 09:13:45 +00:00
										 |  |  | .. method:: MimeTypes.guess_type(url, strict=True)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Similar to the :func:`guess_type` function, using the tables stored as part of
 | 
					
						
							|  |  |  |    the object.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  | .. method:: MimeTypes.guess_all_extensions(type, strict=True)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Similar to the :func:`guess_all_extensions` function, using the tables stored
 | 
					
						
							|  |  |  |    as part of the object.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  | .. method:: MimeTypes.read(filename, strict=True)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Load MIME information from a file named *filename*.  This uses :meth:`readfp` to
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    parse the file.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    If *strict* is ``True``, information will be added to list of standard types,
 | 
					
						
							|  |  |  |    else to the list of non-standard types.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  | .. method:: MimeTypes.readfp(fp, strict=True)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    Load MIME type information from an open file *fp*.  The file must have the format of
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    the standard :file:`mime.types` files.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    If *strict* is ``True``, information will be added to the list of standard
 | 
					
						
							|  |  |  |    types, else to the list of non-standard types.
 | 
					
						
							| 
									
										
										
										
											2009-11-15 14:25:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. method:: MimeTypes.read_windows_registry(strict=True)
 | 
					
						
							| 
									
										
										
										
											2009-11-15 14:25:16 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Load MIME type information from the Windows registry.  Availability: Windows.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-23 10:52:42 +08:00
										 |  |  |    If *strict* is ``True``, information will be added to the list of standard
 | 
					
						
							|  |  |  |    types, else to the list of non-standard types.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-15 14:25:16 +00:00
										 |  |  |    .. versionadded:: 3.2
 |