Python 发送邮件

这篇博客介绍了如何在Python 3环境下发送邮件,并详细讲述了如何附加Excel文件作为邮件附件,提供了相关教程链接和实战经验。
摘要由CSDN通过智能技术生成

种子灵感

http://www.runoob.com/python/python-email.html

https://blog.csdn.net/xiaosongbk/article/details/60142996

项目中实际使用

发送附件, excel 文件
注意使用 Python 3的环境不会考虑太多 编码转化等问题

import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.header import Header
from email import encoders
from email.mime.base import MIMEBase
from email.utils import parseaddr, formataddr
from Tools.oyyo_datetime import OYYODatetime

SMTP_SERVER = 'xxx.com.cn'  # 发送邮件服务器
FROM_MAIL = 'xxx.com.cn'  # 发送邮件用户名
MAIL_PASS = 'xxx'  # 密码

TO_MAIL = ['2219386421@qq.com']  # yang

BODY = " 请查收!"
SUBJECT = '请查收!'


class SendEmail(object):
    def __init__(self):
        pass

    def formatAddr(self, s):
        """格式化邮件地址"""
        name, addr = parseaddr(s)
        return formataddr((Header(name, 'utf-8').encode(), addr))

    def send_email(self, path):
        smtp_server = SMTP_SERVER
        from_mail = FROM_MAIL
        mail_pass = MAIL_PASS
        to_mail = TO_MAIL
        body = BODY
        # 构造一个MIMEMultipart对象代表邮件本身
        msg = MIMEMultipart()
        # Header对中文进行转码
        msg['From'] = Header("服务端", 'utf-8')
        msg['To'] = Header("运营", 'utf-8')
        now = OYYODatetime.get_now_string()
        sub = SUBJECT + " " + now
        print(sub)
        subject = sub
        msg['Subject'] = Header(subject, 'utf-8')
        # plain代表纯文本
        msg.attach(MIMEText(body, 'plain', 'utf-8'))

        # att1 = MIMEText(open('aaa.xlsx', 'rb').read(), 'base64', 'utf-8')
        att1 = MIMEText(open(path, 'rb').read(), 'base64', 'utf-8')
        att1["Content-Type"] = 'application/octet-stream'
        # 这里的filename可以任意写,写什么名字,邮件中显示什么名字
        att1["Content-Disposition"] = 'attachment; filename="userAddress.xlsx"'  # 这个名字是和发送出去保持一致的
        msg.attach(att1)

        try:
            s = smtplib.SMTP()
            s.connect(smtp_server, "25")
            s.login(from_mail, mail_pass)
            s.sendmail(from_mail, to_mail, msg.as_string())  # as_string()把MIMEText对象变成str
            s.quit()
            print("成功了")
        except smtplib.SMTPException as e:
            print(("Error: %s") % e)
        print("失败了")


if __name__ == '__main__':
    s = SendEmail()
    # sendMail('请查收!', 'a.txt')
    s.send_email("aaa.xlsx")


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值