注意:以下文章来源于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()