发送邮件是个很简单的需求,但是在实际的使用中依然碰到了很多坑,因此创建了zmail这个项目,让你使用python发送邮件的过程尽可能简单。
GitHub地址:https://github.com/ZYunH/zmail ,觉得ok请star或者fork!!!
其他轮子的缺点:
- 服务端拒信:首要问题。很多其他的轮子需要自己构造MIME和邮件头(通常优化了过程),但经常遭遇拒信,具体原因是其没有正确的定义邮件头,诸如From和To的头信息在使用SMTP时每家服务商检查都会有细微的差别,以及一些平台的差异(win10 localhost乱码导致发件拒信),甚至在你发往不同的地址检查也会有差别(国内发国外需要额外验证一些信息预防垃圾邮件)。
- 构造太麻烦:特别是添加附件的时候,有些还需要额外去自定义类型,体验很差。
- 发送太麻烦:你需要找到你服务商的smtp地址,端口号,有些服务商不是默认的端口(@163.com),有些只能SSL验证(@qq.com),有些需要TLS(@gmailcom),一个不小心就发送失败。
- 引入过多的外部包:一些轮子引入了好几个包,可能会造成包与原来的程序版本冲突(常见于requests之类的包),并且发生错误无法得到及时的文档支持。在我尝试发送失败后,使用django的email模块成功发送了邮件,但是django的目的显然不是这个,使用一个如此大的框架来实现那么小的需求显然不合理(并且构造过程依然复杂)。
Zmail的优势:
- 自动填充大多数导致服务端拒信的头信息(From To LocalHost之类的)
- 将一个字典映射为email,构造信件就像构造字典一样简单
- 自动寻找邮件服务商端口号地址,自动选择合适的协议(经过认证的)
- 只依赖于python3,嵌入其他项目时无需烦恼
你可以使用zmail来:
- 作为监控脚本的发送邮件模块,及时传递信息
- 嵌入到已有的项目中实现功能
- 自定义邮件发送过程,诸如准点发送、定时发送等
安装
$ pip3 install zmail
也可以使用pip代替pip3
注意:zmail仅支持python3,不支持python2
简单的例子
- 使用前注意,所有邮箱都要开启SMTP功能,@163.com和@gmail.com 的邮箱需要额外设定SMTP密码,网上很多信息,具体自行百度google,这里先行省略。
发送邮件
import zmail
# 你的邮件内容
mail_content = {
'subject': 'Success!', # 随便填写
'content': 'This message from zmail!', # 随便填写
}
# 将你的邮件编码为MIME实例
mail = zmail.encode_mail(mail_content)
# 使用你的邮件账户名和密码登录服务器
server = zmail.server('12345678@qq.com, '你的qq邮箱密码')
# 发送邮件
server.send_mail('555555@qq.com', mail)
- 为你的邮件添加附件,修改 你的邮件内容 即可,其他内容同上
# 你的邮件内容
mail_content = {
'subject': 'Success!', # 随便填写
'content': 'This message from zmail!', # 随便填写
'attachments': '/Users/zyh/Documents/example.zip', # 最好使用绝对路径,若你电脑没有这个文件会造成错误
}
- 给多个信箱发件,修改 发送邮件 即可,其他内容同上
# 发送邮件
server.send_mail(['555555@qq.com','666666@qq.com'], mail)
- 添加额外的头信息,直接加入到mail_content即可
认证过的服务商列表:
地址 | SMTP |
---|---|
@qq.com | ✓ |
@126.com | ✓ |
@yeah.net | ✓ |
@gmail.com | ✓ |
@sina.com | ✓ |
@163.com | ✓ |
不在此列表也无需担心,经过测试,目前尚未发现不支持的邮件服务商,如果遇到问题请及时联系作者(本平台或github)
更多
zmail的POP3功能正在测试中,API设计尚未确定,所以暂时不表。