首页 > 代码库 > python3.x下 smtp发送html邮件和附件
python3.x下 smtp发送html邮件和附件
综合网络上的文章以及自己的实验,在python的IDEL下成功的通过SMTP发送出去了邮件。现将过程记录如下:
一、准备工作:
1、安装好python3.x
2、拥有一个支持smtp服务的邮箱,我是用的126的邮箱 网易和腾讯的邮箱的密码现在都变为授权码登录。需要搜集这些信息:SMTP服务器地址,你的邮箱账号,授权码。
二、思路
发送HTML和带附件的邮件,我们要用到先把html文件组合到一起,做为一个整体。可以理解为作为一个邮包。然后通过SMTP协议传输出去。这个SMTP是传输协议。那么我们用python只需要操作创建连接和发送的部分代码。下面把代码贴出来
import smtplib from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart from email.mime.application import MIMEApplication import traceback my_sender = ‘发件人的邮箱地址‘ my_passwd = ‘发件人的密码,网易、腾讯是用授权码‘ my_user = ‘收件人的邮箱地址‘ my_smtp_host=‘smtp.126.com‘ #126的smtp服务器地址 def mail(): ret = True try: #开始打包邮件 msg=MIMEMultipart() msg[‘From‘]=formataddr([‘发件人邮件昵称‘,my_sender])#设置发件人 msg[‘To‘] = formataddr([‘收件人邮件昵称‘,my_user])#设置收件人 msg[‘Subject‘]=‘这个是邮件的主题‘ #下面是正文内容 pureText = MIMEText(open(‘release-notes.html‘, ‘rb‘).read(),‘html‘,‘utf-8‘) #随便找的html文件,后面两个参数是告诉程序以html格式和utf-8字符 msg.attach(pureText) #下面是各种类型的附件了 # 首先是xlsx类型的附件 xlsxpart = MIMEApplication(open(‘test.xlsx‘, ‘rb‘).read()) xlsxpart.add_header(‘Content-Disposition‘, ‘attachment‘, filename=‘test.xlsx‘) msg.attach(xlsxpart) # jpg类型的附件 jpgpart = MIMEApplication(open(‘2.jpg‘, ‘rb‘).read()) jpgpart.add_header(‘Content-Disposition‘, ‘attachment‘, filename=‘2.jpg‘) msg.attach(jpgpart) #下面开始发送了 server=smtplib.SMTP(my_smtp_host,25)#smtp服务器端口默认是25 # server.set_debuglevel(1)# 设置为调试模式,就是在会话过程中会有输出信息 server.login(my_sender,my_passwd) server.sendmail(my_sender,[my_user,],msg.as_string()) server.quit() except Exception : ret = False return ret ret = mail() if ret: print("ok") else: print(‘failed‘)
从上面的注释可以看出来,大体的步骤了。下面是收到的邮件,有图有真相
下面的Gradle Release Notes 是我随便找的html文件读出来的内容
备注:
release-notes.html test.xlsx 2.jpg 都是和代码在同一目录里面的
有问题,可以留言讨论
本文出自 “展翅飞翔” 博客,谢绝转载!
python3.x下 smtp发送html邮件和附件
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。