python使用QQ邮箱实现自动发送邮件
更新时间:2020年06月22日 17:10:24 作者:技术提高效率
这篇文章主要为大家详细介绍了python使用QQ邮箱实现自动发送邮件,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
最近用到Python自动发送邮件,主要就是三步,登录邮件、写邮件内容、发送,用到的库是 smtplib 和 email,直接使用pip安装即可
我使用的是QQ邮箱,首先需要设置QQ邮箱POP3/SMTP服务
记住这个授权码,这个授权码就是Python脚本中登录邮箱时的密码,而不是你平时登录邮箱时的那个密码
一.发送普通文本邮件
#发送多种类型的邮件 from email.mime.multipart import MIMEMultipart msg_from = '1508691067@qq.com' # 发送方邮箱 passwd = 'xxx' #就是上面的授权码 to= ['1508691067@qq.com'] #接受方邮箱 #设置邮件内容 #MIMEMultipart类可以放任何内容 msg = MIMEMultipart() conntent="这个是字符串" #把内容加进去 msg.attach(MIMEText(conntent,'plain','utf-8')) #设置邮件主题 msg['Subject']="这个是邮件主题" #发送方信息 msg['From']=msg_from #开始发送 #通过SSL方式发送,服务器地址和端口 s = smtplib.SMTP_SSL("smtp.qq.com", 465) # 登录邮箱 s.login(msg_from, passwd) #开始发送 s.sendmail(msg_from,to,msg.as_string()) print("邮件发送成功")
二.发送携带附件的邮件
import smtplib from email.mime.text import MIMEText #发送多种类型的邮件 from email.mime.multipart import MIMEMultipart msg_from = '1508691067@qq.com' # 发送方邮箱 passwd = 'xxxxx' to= ['1508691067@qq.com'] #接受方邮箱 #设置邮件内容 #MIMEMultipart类可以放任何内容 msg = MIMEMultipart() conntent="这个是字符串" #把内容加进去 msg.attach(MIMEText(conntent,'plain','utf-8')) #添加附件 att1=MIMEText(open('result.xlsx','rb').read(),'base64','utf-8') #打开附件 att1['Content-Type']='application/octet-stream' #设置类型是流媒体格式 att1['Content-Disposition']='attachment;filename=result.xlsx' #设置描述信息 msg.attach(att1) #加入到邮件中 #设置邮件主题 msg['Subject']="这个是邮件主题" #发送方信息 msg['From']=msg_from #开始发送 #通过SSL方式发送,服务器地址和端口 s = smtplib.SMTP_SSL("smtp.qq.com", 465) # 登录邮箱 s.login(msg_from, passwd) #开始发送 s.sendmail(msg_from,to,msg.as_string()) print("邮件发送成功")
三.发送携带图片的附件
同理,可以使用上面的方法也可以发送图片附件
import smtplib from email.mime.text import MIMEText #发送多种类型的邮件 from email.mime.multipart import MIMEMultipart msg_from = '1508691067@qq.com' # 发送方邮箱 passwd = 'xxxxx' to= ['1508691067@qq.com'] #接受方邮箱 #设置邮件内容 #MIMEMultipart类可以放任何内容 msg = MIMEMultipart() conntent="这个是字符串" #把内容加进去 msg.attach(MIMEText(conntent,'plain','utf-8')) #添加附件 att1=MIMEText(open('result.xlsx','rb').read(),'base64','utf-8') #打开附件 att1['Content-Type']='application/octet-stream' #设置类型是流媒体格式 att1['Content-Disposition']='attachment;filename=result.xlsx' #设置描述信息 att2=MIMEText(open('1.jpg','rb').read(),'base64','utf-8') att2['Content-Type']='application/octet-stream' #设置类型是流媒体格式 att2['Content-Disposition']='attachment;filename=1.jpg' #设置描述信息 msg.attach(att1) #加入到邮件中 msg.attach(att2) #设置邮件主题 msg['Subject']="这个是邮件主题" #发送方信息 msg['From']=msg_from #开始发送 #通过SSL方式发送,服务器地址和端口 s = smtplib.SMTP_SSL("smtp.qq.com", 465) # 登录邮箱 s.login(msg_from, passwd) #开始发送 s.sendmail(msg_from,to,msg.as_string()) print("邮件发送成功")
四.发送 html 格式的邮件
import smtplib from email.mime.text import MIMEText #发送多种类型的邮件 from email.mime.multipart import MIMEMultipart import datetime msg_from = '1508691067@qq.com' # 发送方邮箱 passwd = 'xxxxxx' to= ['1508691067@qq.com'] #接受方邮箱 #设置邮件内容 #MIMEMultipart类可以放任何内容 msg = MIMEMultipart() # conntent="这个是字符串" # #把内容加进去 # msg.attach(MIMEText(conntent,'plain','utf-8')) #添加附件 att1=MIMEText(open('result.xlsx','rb').read(),'base64','utf-8') #打开附件 att1['Content-Type']='application/octet-stream' #设置类型是流媒体格式 att1['Content-Disposition']='attachment;filename=result.xlsx' #设置描述信息 att2=MIMEText(open('1.jpg','rb').read(),'base64','utf-8') att2['Content-Type']='application/octet-stream' #设置类型是流媒体格式 att2['Content-Disposition']='attachment;filename=1.jpg' #设置描述信息 msg.attach(att1) #加入到邮件中 msg.attach(att2) now_time = datetime.datetime.now() year = now_time.year month = now_time.month day = now_time.day mytime = str(year) + " 年 " + str(month) + " 月 " + str(day) + " 日 " fayanren="爱因斯坦" zhuchiren="牛顿" #构造HTML content = ''' <html> <body> <h1 align="center">这个是标题,xxxx通知</h1> <p><strong>您好:</strong></p> <blockquote><p><strong>以下内容是本次会议的纪要,请查收!</strong></p></blockquote> <blockquote><p><strong>发言人:{fayanren}</strong></p></blockquote> <blockquote><p><strong>主持人:{zhuchiren}</strong></p></blockquote> <p align="right">{mytime}</p> <body> <html> '''.format(fayanren=fayanren, zhuchiren=zhuchiren, mytime=mytime) msg.attach(MIMEText(content,'html','utf-8')) #设置邮件主题 msg['Subject']="这个是邮件主题" #发送方信息 msg['From']=msg_from #开始发送 #通过SSL方式发送,服务器地址和端口 s = smtplib.SMTP_SSL("smtp.qq.com", 465) # 登录邮箱 s.login(msg_from, passwd) #开始发送 s.sendmail(msg_from,to,msg.as_string()) print("邮件发送成功")
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
Python实现批量识别银行卡号码以及自动写入Excel表格步骤详解
这篇文章主要介绍了使用Python实现高效摸鱼,批量识别银行卡号码并且自动写入Excel表格,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧2023-01-01
最新评论