Skip to main content

Democritus functions for working with emails.

Project description

Democritus Emails

PyPI CI Lint codecov The Democritus Project uses semver version 2.0.0 The Democritus Project uses ruff to format and lint code License: LGPL v3

Democritus functions[1] for working with emails.

[1] Democritus functions are simple, effective, modular, well-tested, and well-documented Python functions.

We use d8s (pronounced "dee-eights") as an abbreviation for democritus (you can read more about this here).

Installation

pip install d8s-emails

Usage

You import the library like:

from d8s_emails import *

Once imported, you can use any of the functions listed below.

Functions

  • def is_email(possible_email_text: str) -> bool:
        """Determine if the given string is an email."""
    
  • def email_header_date_fix(email_text: str):
        """Fix the `Date` header in the given email email_text."""
    
  • def email_read(email_string: str):
        """."""
    
  • def email_object_new():
        """."""
    
  • def email_content_transfer_encoding(email_text):
        """Get the content-transfer-encoding for the email (see https://www.w3.org/Protocols/rfc1341/5_Content-Transfer-Encoding.html)."""
    
  • def email_bodies_as_strings(email_text):
        """Return the bodies (as strings) for the given email."""
    
  • def email_bodies_as_objects(email_text):
        """Return the bodies (as objects) for the given email."""
    
  • def email_attachments(email_text):
        """Return the attachments (as strings) for the given email."""
    
  • def email_attachments_objects(email_text):
        """Return the attachments (as objects) for the given email."""
    
  • def email_body_is_base64(email_text):
        """Determine if the body of the email is encoded using base64."""
    
  • def email_header_fields(email_text):
        """Get the header fields in the email."""
    
  • def email_headers(email_text):
        """Get the values of the header fields in the email."""
    
  • def email_headers_raw(email_text):
        """Get the raw (undecoded) values of the header fields in the email."""
    
  • def email_headers_as_dict(email_text) -> Dict[str, List[str]]:
        """Return email's header fields as a dictionary with the header field key as the dictionary's key and the header field value as the dictionary's value."""
    
  • def email_header(email_text, header_field):
        """Get the value(s) for the given header fields."""
    
  • def email_header_delete_field(email_text, header_field):
        """Delete the header_field from the email_text."""
    
  • def email_structure(email_text):
        """Get the structure of the email (this function was inspired by the function here: https://github.com/python/cpython/blob/4993cc0a5b34dc91da2b41c50e33d809f0191355/Lib/email/iterators.py#L59 - which is described here: https://docs.python.org/3.5/library/email.iterators.html?highlight=_structure#email.iterators._structure)."""
    
  • def email_header_add_raw(email, header_name, header_value):
        """Add a header to the email."""
    
  • def email_header_add(email, header_name, header_value):
        """Add a header to the email."""
    

Development

👋  If you want to get involved in this project, we have some short, helpful guides below:

If you have any questions or there is anything we did not cover, please raise an issue and we'll be happy to help.

Credits

This package was created with Cookiecutter and Floyd Hightower's Python project template.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

d8s_emails-0.7.0.tar.gz (100.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

d8s_emails-0.7.0-py3-none-any.whl (21.0 kB view details)

Uploaded Python 3

File details

Details for the file d8s_emails-0.7.0.tar.gz.

File metadata

  • Download URL: d8s_emails-0.7.0.tar.gz
  • Upload date:
  • Size: 100.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for d8s_emails-0.7.0.tar.gz
Algorithm Hash digest
SHA256 058971f308378a158d805db9d9bb7f2e821f08f18a063c1e8ba647ed46f65e52
MD5 7f3439ed8d30d41f926a078dd325aced
BLAKE2b-256 0ecc2256058184d4bbcd0fff749354b19b591da42ae3d34d84afcca112119e6f

See more details on using hashes here.

Provenance

The following attestation bundles were made for d8s_emails-0.7.0.tar.gz:

Publisher: release-please.yml on democritus-project/d8s-emails

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file d8s_emails-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: d8s_emails-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 21.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for d8s_emails-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2450362c0d9dad24f4ebb10e2c3b3b47446a128c5e56db4679a5b382db473ea6
MD5 af3ab17137e28e67fefa3f11188cea31
BLAKE2b-256 bc73705f29e59eef2d8c335c8f75b095bb664d08b72ae4b02447ce6eddb2f0c0

See more details on using hashes here.

Provenance

The following attestation bundles were made for d8s_emails-0.7.0-py3-none-any.whl:

Publisher: release-please.yml on democritus-project/d8s-emails

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page