自动发送邮件

注意:以下文章来源于Python大数据分析 ,作者朱卫军

# 1、导入相关的库和方法
import smtplib
import email
# 负责构造文本
from email.mime.text import MIMEText
# 负责构造图片
from email.mime.image import MIMEImage
# 负责将多个对象集合起来
from email.mime.multipart import MIMEMultipart
from email.header import Header

# 2、设置邮箱域名、发件人邮箱、邮箱授权码、收件人邮箱
# SMTP 服务器,这里使用qq邮箱
mail_host = "smtp.qq.com"
# 发件人邮箱
mail_sender = "**********@qq.com"
# 邮箱授权码,注意这里不是邮箱密码
mail_license = "**********"
# 收件人邮箱,可以为多个收件人
mail_receivers = ['**********@qq.com','**********@163.com']

# 3、构建 MIMEMultipart 对象代表邮件本身,可以忘里面添加文本、图片、附件等
mm = MIMEMultipart('related')

# 4、设置邮件头部
# 邮件主题
subject_content = "Python邮件测试"
# 设置发送者,注意严格遵守格式,里面邮箱为发件人邮箱
mm['From'] = "send_name<*********@qq.com>"
# 设置接收者,注意严格遵守格式,里面邮箱为接收者邮箱
mm['To'] = "receiver_1_name<*********@163.com>,receiver_2_name<*********@qq.com>"
# 设置邮件主题
mm['Subject'] = Header(subject_content,'utf-8')

# 5、添加正文文本
# 邮件正文内容
body_content = "你好,这是测试邮件!"
# 构造文本,参数1:正文内容,参数2:文本格式,参数3:编码方式
message_text = MIMEText(body_content,'plain','utf-8')
# 向 MIMEMultipart 对象中添加文本对象
mm.attach(message_text)

# 6、添加图片
# 二进制读取图片
image_data = open('12.jpg','rb')
# 设置读取获取的二进制数据
message_image = MIMEImage(image_data.read())
# 关闭刚才打开的文件
image_data.close()
# 添加图片文件到邮件信息当中去
mm.attach(message_image)

# 7、添加附件(excel 表格)
# 构造附件
atta = MIMEText(open('info.xls','rb').read(),'base64','utf-8')
# 设置附件信息
atta['Content-Disposition'] = 'attachment; filename="info.xls"'
# 添加附件到邮件信息当中去
mm.attach(atta)

# 8、发送邮件
# 创建 SMTP 对象
stp = smtplib.SMTP()
# 设置发件人邮件的域名和端口,端口地址为25
stp.connect(mail_host,25)
# stp.set_debuglevel(1) 可以打印出和 SMTP 服务器交互的所有信息
stp.set_debuglevel(1)
# 登录邮箱,传递参数1:邮箱地址,参数2:邮箱授权码
stp.login(mail_sender,mail_license)
# 发送邮件,传递参数1:发件人邮箱地址,参数2:收件人邮箱地址,参数3:把邮件内容格式改为str
stp.sendmail(mail_sender,mail_receivers,mm.as_string())
print("邮件发送成功")
# 关闭 SMTP 对象
stp.quit()

  

原文地址:https://www.cnblogs.com/siyu0123/p/12877673.html