mirror of
				https://github.com/python/cpython.git
				synced 2025-11-03 11:23:31 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			152 lines
		
	
	
	
		
			6.6 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			152 lines
		
	
	
	
		
			6.6 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
:mod:`email` --- An email and MIME handling package
 | 
						|
===================================================
 | 
						|
 | 
						|
.. module:: email
 | 
						|
   :synopsis: Package supporting the parsing, manipulating, and generating
 | 
						|
              email messages.
 | 
						|
.. moduleauthor:: Barry A. Warsaw <barry@python.org>,
 | 
						|
                  R. David Murray <rdmurray@bitdance.com>
 | 
						|
.. sectionauthor:: R. David Murray <rdmurray@bitdance.com>
 | 
						|
 | 
						|
**Source code:** :source:`Lib/email/__init__.py`
 | 
						|
 | 
						|
--------------
 | 
						|
 | 
						|
The :mod:`email` package is a library for managing email messages.  It is
 | 
						|
specifically *not* designed to do any sending of email messages to SMTP
 | 
						|
(:rfc:`2821`), NNTP, or other servers; those are functions of modules such as
 | 
						|
:mod:`smtplib` and :mod:`nntplib`.  The :mod:`email` package attempts to be as
 | 
						|
RFC-compliant as possible, supporting :rfc:`5233` and :rfc:`6532`, as well as
 | 
						|
such MIME-related RFCs as :rfc:`2045`, :rfc:`2046`, :rfc:`2047`, :rfc:`2183`,
 | 
						|
and :rfc:`2231`.
 | 
						|
 | 
						|
The overall structure of the email package can be divided into three major
 | 
						|
components, plus a fourth component that controls the behavior of the other
 | 
						|
components.
 | 
						|
 | 
						|
The central component of the package is an "object model" that represents email
 | 
						|
messages.  An application interacts with the package primarily through the
 | 
						|
object model interface defined in the :mod:`~email.message` sub-module.  The
 | 
						|
application can use this API to ask questions about an existing email, to
 | 
						|
construct a new email, or to add or remove email subcomponents that themselves
 | 
						|
use the same object model interface.  That is, following the nature of email
 | 
						|
messages and their MIME subcomponents, the email object model is a tree
 | 
						|
structure of objects that all provide the :class:`~email.message.EmailMessage`
 | 
						|
API.
 | 
						|
 | 
						|
The other two major components of the package are the :mod:`~email.parser` and
 | 
						|
the :mod:`~email.generator`.  The parser takes the serialized version of an
 | 
						|
email message (a stream of bytes) and converts it into a tree of
 | 
						|
:class:`~email.message.EmailMessage` objects.  The generator takes an
 | 
						|
:class:`~email.message.EmailMessage` and turns it back into a serialized byte
 | 
						|
stream.  (The parser and generator also handle streams of text characters, but
 | 
						|
this usage is discouraged as it is too easy to end up with messages that are
 | 
						|
not valid in one way or another.)
 | 
						|
 | 
						|
The control component is the :mod:`~email.policy` module.  Every
 | 
						|
:class:`~email.message.EmailMessage`, every :mod:`~email.generator`, and every
 | 
						|
:mod:`~email.parser` has an associated :mod:`~email.policy` object that
 | 
						|
controls its behavior.  Usually an application only needs to specify the policy
 | 
						|
when an :class:`~email.message.EmailMessage` is created, either by directly
 | 
						|
instantiating an :class:`~email.message.EmailMessage`  to create a new email,
 | 
						|
or by parsing an input stream using a :mod:`~email.parser`.  But the policy can
 | 
						|
be changed when the message is serialized using a :mod:`~email.generator`.
 | 
						|
This allows, for example, a generic email message to be parsed from disk, but
 | 
						|
to serialize it using standard SMTP settings when sending it to an email
 | 
						|
server.
 | 
						|
 | 
						|
The email package does its best to hide the details of the various governing
 | 
						|
RFCs from the application.  Conceptually the application should be able to
 | 
						|
treat the email message as a structured tree of unicode text and binary
 | 
						|
attachments, without having to worry about how these are represented when
 | 
						|
serialized.  In practice, however, it is often necessary to be aware of at
 | 
						|
least some of the rules governing MIME messages and their structure,
 | 
						|
specifically the names and nature of the MIME "content types" and how they
 | 
						|
identify multipart documents.  For the most part this knowledge should only be
 | 
						|
required for more complex applications, and even then it should only be the
 | 
						|
high level structure in question, and not the details of how those structures
 | 
						|
are represented.  Since MIME content types are used widely in modern internet
 | 
						|
software (not just email), this will be a familiar concept to many programmers.
 | 
						|
 | 
						|
The following sections describe the functionality of the :mod:`email` package.
 | 
						|
We start with the :mod:`~email.message` object model, which is the primary
 | 
						|
interface an application will use, and follow that with the
 | 
						|
:mod:`~email.parser` and :mod:`~email.generator` components.  Then we cover the
 | 
						|
:mod:`~email.policy` controls, which completes the treatment of the main
 | 
						|
components of the library.
 | 
						|
 | 
						|
The next three sections cover the exceptions the package may raise and the
 | 
						|
defects (non-compliance with the RFCs) that the :mod:`~email.parser` may
 | 
						|
detect.  Then we cover the :mod:`~email.headerregistry` and the
 | 
						|
:mod:`~email.contentmanager` sub-components, which provide tools for doing more
 | 
						|
detailed manipulation of headers and payloads, respectively.  Both of these
 | 
						|
components contain features relevant to consuming and producing non-trivial
 | 
						|
messages, but also document their extensibility APIs, which will be of interest
 | 
						|
to advanced applications.
 | 
						|
 | 
						|
Following those is a set of examples of using the fundamental parts of the APIs
 | 
						|
covered in the preceding sections.
 | 
						|
 | 
						|
The foregoing represent the modern (unicode friendly) API of the email package.
 | 
						|
The remaining sections, starting with the :class:`~email.message.Message`
 | 
						|
class, cover the legacy :data:`~email.policy.compat32` API that deals much more
 | 
						|
directly with the details of how email messages are represented.  The
 | 
						|
:data:`~email.policy.compat32` API does *not* hide the details of the RFCs from
 | 
						|
the application, but for applications that need to operate at that level, they
 | 
						|
can be useful tools.  This documentation is also relevant for applications that
 | 
						|
are still using the :mod:`~email.policy.compat32` API for backward
 | 
						|
compatibility reasons.
 | 
						|
 | 
						|
.. versionchanged:: 3.6
 | 
						|
   Docs reorganized and rewritten to promote the new
 | 
						|
   :class:`~email.message.EmailMessage`/:class:`~email.policy.EmailPolicy`
 | 
						|
   API.
 | 
						|
 | 
						|
Contents of the :mod:`email` package documentation:
 | 
						|
 | 
						|
.. toctree::
 | 
						|
 | 
						|
   email.message.rst
 | 
						|
   email.parser.rst
 | 
						|
   email.generator.rst
 | 
						|
   email.policy.rst
 | 
						|
 | 
						|
   email.errors.rst
 | 
						|
   email.headerregistry.rst
 | 
						|
   email.contentmanager.rst
 | 
						|
 | 
						|
   email.examples.rst
 | 
						|
 | 
						|
Legacy API:
 | 
						|
 | 
						|
.. toctree::
 | 
						|
 | 
						|
   email.compat32-message.rst
 | 
						|
   email.mime.rst
 | 
						|
   email.header.rst
 | 
						|
   email.charset.rst
 | 
						|
   email.encoders.rst
 | 
						|
   email.utils.rst
 | 
						|
   email.iterators.rst
 | 
						|
 | 
						|
 | 
						|
.. seealso::
 | 
						|
 | 
						|
   Module :mod:`smtplib`
 | 
						|
      SMTP (Simple Mail Transport Protocol) client
 | 
						|
 | 
						|
   Module :mod:`poplib`
 | 
						|
      POP (Post Office Protocol) client
 | 
						|
 | 
						|
   Module :mod:`imaplib`
 | 
						|
      IMAP (Internet Message Access Protocol) client
 | 
						|
 | 
						|
   Module :mod:`nntplib`
 | 
						|
      NNTP (Net News Transport Protocol) client
 | 
						|
 | 
						|
   Module :mod:`mailbox`
 | 
						|
      Tools for creating, reading, and managing collections of messages on disk
 | 
						|
      using a variety standard formats.
 | 
						|
 | 
						|
   Module :mod:`smtpd`
 | 
						|
      SMTP server framework (primarily useful for testing)
 |