Python自动发邮件核心是smtplib和email库,需配置SMTP地址端口、授权码,处理编码与附件;支持纯文本、HTML正文及Excel等附件,可集成定时任务与办公流程。
Python 实现自动邮件发送,核心是使用 smtplib(发信)和 email(构造邮件内容)标准库,配合邮箱 SMTP 服务即可完成。关键在于正确配置发件邮箱的 SMTP 地址、端口、登录凭证,并处理好纯文本/HTML 正文、附件、中文编码等细节。
不同邮箱服务商的 SMTP 设置不同,常见如下(需开启“SMTP服务”或“POP3/IMAP/SMTP服务”,并生成专用密码或开启授权码):
⚠️ 注意:不要在代码里硬写明文密码;推荐用环境变量或配置文件管理敏感信息。
以下是一个可直接运行的最小示例(以 QQ 邮箱为例):
import smtplib from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart import os配置(建议从环境变量读取)
sender = "your_email@qq.com" password = os.getenv("QQ_EMAIL_PASS") # 在终端执行:export QQ_EMAIL_PASS="你的授权码" receiver = "target@domain.com"
构建邮件
msg = MIMEMultipart() msg["From"] = sender msg["To"] = receiver msg["Subject"] = "【Python自动发送】测试邮件"
添加正文(纯文本)
body = "这是一封由 Python 自动发送的办公邮件。" msg.attach(MIMEText(body, "plain", "utf-8"))
发送
try: server = smtplib.SMTP("smtp.qq.com", 587) server.starttls() # 启用 TLS 加密 server.login(sender, password) server.send_message(msg) server.quit() print("✅ 邮件发送成功") except Exception as e: print("❌ 发送失败:", e)
办公场景常需格式化内容或附上 Excel/PDF 报表。只需稍作扩展:
MIMEText(html_content, "html", "utf-8") 替换纯文本部分,即可渲染表格、加粗、换行等email.mime.base.MIMEBase 读取文件并编码(如 base64),再 attach 进 msgemail.header.Header 编码,避免乱码(多数现代邮箱已兼容,但稳妥起见建议处理)例如添加一个本地 Excel 文件作为附件:
from email.mime.base import MIMEBase from email import encoderswith open("report.xlsx", "rb") as f: part = MIMEBase("application", "vnd.openxmlformats-officedocument.spreadsheetml.sheet") part.set_payload(f.read()) encoders.encode_base64(part) part.add_header( "Content-Disposition", f"attachment; filename=report.xlsx", filename="report.xlsx" ) msg.attach(part)
自动邮件常作为任务闭环环节,比如:
出 Excel → 自动发给主管搭配 schedule 库可实现定时任务,或部署为 Cron job / Windows 任务计划程序。若需更高可靠性,可加入重试机制、日志记录和异常通知(比如失败时给自己发一封“发送失败告警”邮件)。
基本上就这些。不复杂但容易忽略授权码、编码、附件类型声明等细节。跑通一次后,就能嵌入各种办公场景,真正把重复发邮件这件事交给 Python。