解读Python发送邮件_html/css_WEB-ITnose
解读Python发送邮件
Python发送邮件需要smtplib和email两个模块。也正是由于我们在实际工作中可以导入这些模块,才使得处理工作中的任务变得更加的简单。今天,就来好好学习一下使用Python发送邮件吧。
SMTP是发送邮件的协议,Python内置对SMTP的支持,可以发送纯文本邮件、HTML邮件以及带附件的邮件。
Python对SMTP支持有smtplib和email两个模块,email负责构造邮件,smtplib负责发送邮件。
1.邮件正文是文本的格式
1 # -*- coding: UTF-8 -*- 2 3 from email.mime.multipart import MIMEMultipart 4 from email.mime.text import MIMEText 5 import smtplib 6 import sys 7 import csv 8 import xlrd 9 from pyExcelerator import *10 import os11 import xlwt12 from xlutils.copy import copy13 import pyExcelerator14 import datetime15 import time16 17 reload(sys)18 sys.setdefaultencoding("utf-8")19 20 mailto_list = [""] # 邮件接收方的邮件地址21 mail_host = "smtp.exmail.qq.com" # 邮件传送协议服务器22 mail_user = "" # 邮件发送方的邮箱账号23 mail_pass = "" # 邮件发送方的邮箱密码24 25 def send_mail(to_list, sub, content):26 me = "天才白痴梦"+"<"+mail_user+">"27 msg = MIMEText(content, _subtype='plain', _charset='utf-8')28 msg['Subject'] = sub # 邮件主题29 msg['From'] = me30 msg['To'] = ";".join(to_list)31 try:32 server = smtplib.SMTP()33 server.connect(mail_host)34 server.login(mail_user, mail_pass)35 server.sendmail(me, to_list, msg.as_string())36 server.close()37 return True38 except Exception, e:39 print str(e)40 return False41 42 if __name__ == '__main__':43 sub = "天才白痴梦"44 content = '...'45 if send_mail(mailto_list, sub, content):46 print "发送成功"47 else:48 print "发送失败"
2.邮件正文是表格的格式:由于是表格,所以我们选择HTML来实现表格的功能,邮件上面显示的就是HTML实现的内容了。
1 # -*- coding: UTF-8 -*- 2 3 from email.mime.multipart import MIMEMultipart 4 from email.mime.text import MIMEText 5 import smtplib 6 import sys 7 import csv 8 import xlrd 9 from pyExcelerator import *10 import os11 import xlwt12 from xlutils.copy import copy13 import pyExcelerator14 import datetime15 import time16 17 reload(sys)18 sys.setdefaultencoding("utf-8")19 20 mailto_list = [""] # 邮件接收方的邮件地址21 mail_host = "smtp.exmail.qq.com" # 邮件传送协议服务器22 mail_user = "" # 邮件发送方的邮箱账号23 mail_pass = "" # 邮件发送方的邮箱密码24 25 def send_mail(to_list, sub, content):26 me = "天才白痴梦"+"<"+mail_user+">"27 # 和上面的代码不同的就是,这里我们选择的是html 的格式28 msg = MIMEText(content, _subtype='html', _charset='utf-8')29 msg['Subject'] = sub # 邮件主题30 msg['From'] = me31 msg['To'] = ";".join(to_list)32 try:33 server = smtplib.SMTP()34 server.connect(mail_host)35 server.login(mail_user, mail_pass)36 server.sendmail(me, to_list, msg.as_string())37 server.close()38 return True39 except Exception, e:40 print str(e)41 return False42 43 if __name__ == '__main__':44 sub = "天才白痴梦"45 html = '<html></html>'46 if send_mail(mailto_list, sub, html):47 print "发送成功"48 else:49 print "发送失败"
3.邮件正文是图片的格式:要把图片嵌入到邮件正文中,我们只需按照发送附件的方式,先把邮件作为附件添加进去,然后,在HTML中通过引用src="cid:0"就可以把附件作为图片嵌入了。如果有多个图片,给它们依次编号,然后引用不同的cid:x即可。
1 def send_mail(to_list, sub, content): 2 me = "天才白痴梦"+"<"+mail_user+">" 3 4 msg = MIMEMultipart() 5 msg['Subject'] = sub # 邮件主题 6 msg['From'] = me 7 msg['To'] = ";".join(to_list) 8 9 txt = MIMEText("天才白痴梦", _subtype='plain', _charset='utf8')10 msg.attach(txt)11 12 # <b>:黑体 <i>:斜体13 msgText = MIMEText('<b>Some <i>HTML</i> text</b> and an image.<img src="/static/imghw/default1.png" data-src="cid:image1" class="lazy" alt="" />good!', 'html', 'utf-8')14 msg.attach(msgText)15 16 file1 = "F:\\1.jpg"17 image = MIMEImage(open(file1, 'rb').read())18 image.add_header('Content-ID', '<image1>')19 msg.attach(image)20 21 try:22 server = smtplib.SMTP()23 server.connect(mail_host)24 server.login(mail_user, mail_pass)25 server.sendmail(me, to_list, msg.as_string())26 server.close()27 return True28 except Exception, e:29 print str(e)30 return False31 32 if __name__ == '__main__':33 sub = "天才白痴梦"34 html = '<html></html>'35 if send_mail(mailto_list, sub, html):36 print "发送成功"37 else:38 print "发送失败"
4.发送邮件附件:邮件附件是图片
1 def send_mail(to_list, sub, content): 2 me = "天才白痴梦"+"<"+mail_user+">" 3 4 msg = MIMEMultipart() 5 msg['Subject'] = sub # 邮件主题 6 msg['From'] = me 7 msg['To'] = ";".join(to_list) 8 9 txt = MIMEText("天才白痴梦", _subtype='plain', _charset='utf8')10 msg.attach(txt)11 12 # # <b>:黑体 <i>:斜体13 # msgText = MIMEText('<b>Some <i>HTML</i> text</b> and an image.<img src="/static/imghw/default1.png" data-src="cid:image1" class="lazy" alt="" />good!', 'html', 'utf-8')14 # msg.attach(msgText)15 #16 # file1 = "F:\\1.jpg"17 # image = MIMEImage(open(file1, 'rb').read())18 # image.add_header('Content-ID', '<image1>')19 # msg.attach(image)20 21 att = MIMEText(open('F:\\1.jpg', 'rb').read(), 'base64', 'utf-8')22 att["Content-Type"] = 'application/octet-stream'23 att["Content-Disposition"] = 'attachment; filename="1.jpg"'24 msg.attach(att)25 26 try:27 server = smtplib.SMTP()28 server.connect(mail_host)29 server.login(mail_user, mail_pass)30 server.sendmail(me, to_list, msg.as_string())31 server.close()32 return True33 except Exception, e:34 print str(e)35 return False
5.发送群邮件:同时发送给多人
1 mailto_list = [""] # 邮件接收方的邮件地址
上面这一行代码是邮件接收方的邮件地址,如果我们需要给多人发送邮件的话,就只需要把对方的邮件帐号绑在这一个列表里就ok了。
加密SMTP
使用标准的25端口连接SMTP服务器时,使用的是明文传输,发送邮件的整个过程可能会被窃听。要更安全地发送邮件,可以加密SMTP会话,实际上就是先创建SSL安全连接,然后再使用SMTP协议发送邮件。
方法:只需要在创建SMTP对象后,立刻调用starttls()方法,就创建了安全连接。
1 smtp_server = 'smtp.qq.com'2 smtp_port = 25 # 默认端口号为253 server = smtplib.SMTP(smtp_server, smtp_port)4 server.starttls()5 # 剩下的代码和前面的一模一样:6 server.set_debuglevel(1) # 打印出和SMTP服务器交互的所有信息

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

HTML定义网页结构,CSS负责样式和布局,JavaScript赋予动态交互。三者在网页开发中各司其职,共同构建丰富多彩的网站。

HTML、CSS和JavaScript是Web开发的三大支柱。1.HTML定义网页结构,使用标签如、等。2.CSS控制网页样式,使用选择器和属性如color、font-size等。3.JavaScript实现动态效果和交互,通过事件监听和DOM操作。

HTML、CSS和JavaScript在Web开发中的作用分别是:1.HTML定义网页结构,2.CSS控制网页样式,3.JavaScript添加动态行为。它们共同构建了现代网站的框架、美观和交互性。

HTML的未来充满了无限可能。1)新功能和标准将包括更多的语义化标签和WebComponents的普及。2)网页设计趋势将继续向响应式和无障碍设计发展。3)性能优化将通过响应式图片加载和延迟加载技术提升用户体验。

HTML的未来趋势是语义化和Web组件,CSS的未来趋势是CSS-in-JS和CSSHoudini,JavaScript的未来趋势是WebAssembly和Serverless。1.HTML的语义化提高可访问性和SEO效果,Web组件提升开发效率但需注意浏览器兼容性。2.CSS-in-JS增强样式管理灵活性但可能增大文件体积,CSSHoudini允许直接操作CSS渲染。3.WebAssembly优化浏览器应用性能但学习曲线陡,Serverless简化开发但需优化冷启动问题。

HTML、CSS和JavaScript在网页开发中的角色分别是:HTML负责内容结构,CSS负责样式,JavaScript负责动态行为。1.HTML通过标签定义网页结构和内容,确保语义化。2.CSS通过选择器和属性控制网页样式,使其美观易读。3.JavaScript通过脚本控制网页行为,实现动态和交互功能。

HTML是构建网页结构的基石。1.HTML定义内容结构和语义,使用、、等标签。2.提供语义化标记,如、、等,提升SEO效果。3.通过标签实现用户交互,需注意表单验证。4.使用、等高级元素结合JavaScript实现动态效果。5.常见错误包括标签未闭合和属性值未加引号,需使用验证工具。6.优化策略包括减少HTTP请求、压缩HTML、使用语义化标签等。
