Simplify Python Email Sending with zmail: A Complete Guide

This article introduces the zmail Python library, explains common pitfalls of other email tools, highlights zmail's advantages, and provides step‑by‑step instructions with code examples for installing, sending, receiving, parsing emails and handling attachments, making email automation in Python straightforward.

MaGe Linux Operations
MaGe Linux Operations
MaGe Linux Operations
Simplify Python Email Sending with zmail: A Complete Guide

Introduction

Sending emails is a simple requirement, but many pitfalls still exist in practice; the zmail project was created to make sending emails with Python as easy as possible.

Drawbacks of Other Libraries

Server rejection due to improperly defined headers (From, To, etc.) and provider‑specific checks.

Complex construction, especially when adding attachments.

Sending difficulties: finding SMTP server, port, SSL/TLS requirements.

Parsing challenges: handling bytes, boundaries, and encoding.

Excessive external dependencies causing version conflicts.

Advantages of zmail

Automatically fills most headers that cause server rejections.

Maps a dictionary to an email, making construction as simple as building a dict.

Auto‑detects mail service provider address and port, selects appropriate protocol.

Depends only on Python 3; easy to embed in other projects.

Use Cases

Monitoring scripts for sending/receiving emails.

Embedding email functionality into existing projects.

Custom email sending processes such as scheduled or timed deliveries.

Installation

Install via pip: pip3 install zmail zmail supports only Python 3; ensure SMTP is enabled for your email accounts.

Sending Email

Example code:

import zmail
mail_content = {
'subject': 'Success!',
'content': 'This message from zmail!',
}
server = zmail.server('[email protected]', 'your_password')
server.send_mail('[email protected]', mail_content)

To add attachments, include an 'attachments' key with the file path.

Receiving Email

Retrieve the latest email:

import zmail
server = zmail.server('[email protected]', 'yourpassword')
mail = server.get_latest()

Retrieve by ID: mail = server.get_mail(2) Search by criteria:

mail = server.get_mails(subject='GitHub', after='2018-1-1', sender='github')

Parsing Email

Emails are returned as dictionaries; access fields like: subject = mail['subject'] Display the email:

zmail.show(mail)

Email Structure

content-type

subject

to

from

date

boundary (for multipart)

content (plain text)

contents (body parts)

attachments

id (mailbox ID)

Attachments

Get attachments: zmail.get_attachment(mail) Rename attachment when saving:

zmail.get_attachment(mail, 'example.zip')

Supported Email Providers

The following providers have been tested and work with zmail:

Supported email providers
Supported email providers
Original Source

Signed-in readers can open the original source through BestHub's protected redirect.

Sign in to view source
Republication Notice

This article has been distilled and summarized from source material, then republished for learning and reference. If you believe it infringes your rights, please contactadmin@besthub.devand we will review it promptly.

AutomationEmailSMTPzmail
MaGe Linux Operations
Written by

MaGe Linux Operations

Founded in 2009, MaGe Education is a top Chinese high‑end IT training brand. Its graduates earn 12K+ RMB salaries, and the school has trained tens of thousands of students. It offers high‑pay courses in Linux cloud operations, Python full‑stack, automation, data analysis, AI, and Go high‑concurrency architecture. Thanks to quality courses and a solid reputation, it has talent partnerships with numerous internet firms.

0 followers
Reader feedback

How this landed with the community

Sign in to like

Rate this article

Was this worth your time?

Sign in to rate
Discussion

0 Comments

Thoughtful readers leave field notes, pushback, and hard-won operational detail here.