Python办公自动化【发送普通邮件、发送HTML邮件、发送附件邮件-smtplib、批量发送邮件-smtplib、发送邮件-zmail】(八)-全面详解(学习总结---从入门到深化)

简介: Python办公自动化【发送普通邮件、发送HTML邮件、发送附件邮件-smtplib、批量发送邮件-smtplib、发送邮件-zmail】(八)-全面详解(学习总结---从入门到深化)

发送普通邮件



SMTP(Simple Mail Transfer Protocol)是简单传输协议。


python中对SMTP进行了简单的封装,可以发送纯文本邮件、HTML 邮件以及带附件的邮件。两个核心模块如下:


1、email模块:负责构建邮件

2、smtplib模块:负责发送邮件


常用方法与属性

函数名&属性 含义

smtplib.SMTP(address)

设置邮箱服务器地址

腾讯邮箱:smtp.qq.com

新浪邮箱:smtp.sina.com

新浪VIP:smtp.vip.sina.com

搜狐邮箱:smtp.sohu.com

126邮箱:smtp.126.com

139邮箱:smtp.139.com

163网易邮箱:smtp.163.com

smtp.login(uname,passwd)  登录SMTP服务器
email.mime.text.MIMEText(info,type,encoding)  设置内容
MIMEText['From']  设置发送者名
MIMEText['Subject']  发送邮件主题
SMTP.sendmail(from_addr, to_addrs, msg)  发送邮件
email.header.Header(s=None,charset=None)  创建一个可以包含不同字符集中的字符串,并符合MIME的标头


代码

import smtplib
from email.mime.text import MIMEText
from email.header import Header
def send_email():
  # 设置要登录的邮箱
  smtp_obj = smtplib.SMTP('smtp.qq.com')
  # 登录邮箱
  smtp_obj.login('398707160@qq.com','spcdwgqkltjsaiah')
  # 编辑内容
  mail_text = 'This is Email~ 您要的邮件来啦~~'
  # plain 原生文本模式
  msg_body = MIMEText(mail_text,'plain','utf-8')
  # 设置从哪发送的
  msg_body['From'] = Header('Python学院','utf-8')
  msg_body['Subject'] = Header('测试Python自动邮件','utf-8')
  # 发送邮件
 smtp_obj.sendmail('398707160@qq.com','hotelmail@126.com',msg_body.as_string())
if __name__ =='__main__':
  send_email()


发送HTML邮件



代码

# smtplib
# email
import smtplib
from email.mime.text import MIMEText
from email.header import Header
# 登录邮箱
smtp_obj = smtplib.SMTP("smtp.qq.com")
smtp_obj.login('398707160@qq.com','ppzuouwejpuebgfg')
# 编辑内容
mail_text = '''
<h1 style="color:red">这个是一个HTML邮件</h1>
<p>这是邮件的主题内容</p>
<p><a href="http://www.itbaizhan.cn">这个是链接</a></p>
'''
msg_body = MIMEText(mail_text,'html','utf-8')
msg_body['From'] = Header('测试部门','utf-8')
msg_body['Subject'] = Header('测试邮件','utf-8')
# 发邮件
smtp_obj.sendmail('398707160@qq.com',['hotelmail@126.com'],msg_body.as_string())


发送附件邮件-smtplib



有时邮件的内容只靠文本是无法完全描述内容。这时就可以考虑发送附件来携带内容。具体方法如下:

 

1、设置登录服务器

2、登录邮箱

3、增加附件

4、设置请求头

5、发送邮件


常用方法与属性

函数名&属性 含义
email.mime.application.MIMEApplication 设置附件
MIMEApplication.add_header()  设置请求头,主要是设置文件名
email.mime.multipart.MIMEMultipart  生成包含多个部分的邮件体的 MIME 对象
MIMEMultipart.attach(info)  增加邮件内容


代码

import smtplib
from email.mime.text import MIMEText
from email.mime.application import MIMEApplication
from email.mime.multipart import MIMEMultipart
from email.header import Header
def send_file_email():
  # 设置邮箱服务器
  stmp_obj = smtplib.SMTP('smtp.qq.com')
  # 登录邮箱
 stmp_obj.login('398707160@qq.com','spcdwgqkltjsbiah')
  # 设置邮件内容
  # 文本
  msg_txt = MIMEText('这个带有附件的邮件','plain','utf-8')
  # 附件
  msg_file = MIMEApplication(open('./base_data/backg.jpg','rb').read())
  msg_file.add_header('Content-Disposition','attachment',filename='bg.jpg')
  # 封装要发送的数据
  part = MIMEMultipart()
  part.attach(msg_txt)
  part.attach(msg_file)
  # 设置邮件其它信息
  part['From'] = Header('Python学院','utf-8')
  part['Subject'] = Header('附件邮件','utf-8')
  # 发送邮件
 stmp_obj.sendmail('398707160@qq.com','hotelmail@126.com',part.as_string())
if __name__ =='__main__':
  send_file_email()


批量发送邮件-smtplib



代码

from email.header import Header
from email.mime.text import MIMEText
import smtplib
from openpyxl import load_workbook
def send_many_mail1():
  # 设置登录邮箱服务器
  smtp_obj = smtplib.SMTP('smtp.qq.com')
  # 登录邮箱
 smtp_obj.login('398707160@qq.com','spcdwgqkltjsbiah')
  # 编辑内容
  msg_txt = '''
 <table border="1">
 <tr>
   <td>工号</td>
   <td>姓名</td>
   <td>部门</td>
   <td>基本工资</td>
   <td>提成</td>
   <td>加班工资</td>
   <td>社保扣除</td>
   <td>考勤扣除</td>
   <td>应发工资</td>
   <td>邮箱</td>
 </tr>
 <tr>
   <td>000011</td>
   <td>张杨工</td>
   <td>skldjfsl</td>
   <td>80000</td>
   <td>0</td>
   <td>0</td>
   <td>0</td>
   <td>0</td>
   <td>80000</td>
   <td>aa@qq.com</td>
 </tr>
</table>
 '''
  msg =  MIMEText(msg_txt,'html','utf-8')
  # 设置邮件其他信息
  msg['From'] = Header('百战财务部','utf-8')
  msg['Subject'] = Header('工资条','utf-8')
  #发送邮件
 smtp_obj.sendmail('398707160@qq.com','hotelmail@126.com',msg.as_string())
def send_many_mail2():
  # 设置登录邮箱服务器
  smtp_obj = smtplib.SMTP('smtp.qq.com')
  # 登录邮箱
 smtp_obj.login('398707160@qq.com','spcdwgqkltjsbiah')
  # 打开excel文件
  wb = load_workbook('./base_data/工资数据.xlsx',data_only=True)
  # 激活工作簿
  sh = wb.active
  # 读取数据-遍历
  for i,r in enumerate(sh.iter_rows()):
    if i != 0:
      # 编辑内容
      msg_txt = f'''
     <h3>您好:{r[1].value}</h3>
     <p>请查收2030年12月工资条详情:</p>
     <table border="1">
    <tr>
       <td>工号</td>
       <td>姓名</td>
       <td>部门</td>
       <td>基本工资</td>
       <td>提成</td>
       <td>加班工资</td>
       <td>社保扣除</td>
       <td>考勤扣除</td>
       <td>应发工资</td>
       <td>邮箱</td>
     </tr>
     <tr>
       <td>{r[0].value}</td>
       <td>{r[1].value}</td>
       <td>{r[2].value}</td>
       <td>{r[3].value}</td>
       <td>{r[4].value}</td>
       <td>{r[5].value}</td>
       <td>{r[6].value}</td>
       <td>{r[7].value}</td>
       <td>{r[8].value}</td>
       <td>{r[9].value}</td>
     </tr>
   </table>
     '''
      msg = MIMEText(msg_txt,'html','utf-8')
      # 设置邮件其他信息
      msg['From'] = Header('财务部','utf-8')
      msg['Subject'] = Header('工资条','utf-8')
      #发送邮件
      smtp_obj.sendmail('398707160@qq.com',{r[9].value},msg.as_string())
      print(f'{r[1].value} 工资条发送成功!!')
if __name__ =='__main__':
  send_many_mail2()


发送邮件-zmail



Zmail的优势


1、自动填充大多数导致服务端拒信的头信息(From To LocalHost之类的)

2、将一个字典映射为email,构造信件就像构造字典一样简单

3、自动寻找邮件服务商端口号地址,自动选择合适的协议(经过认证的)


安装

pip install zmail


常用方法与属性

函数名&属性 含义
zmail.server(name,password) 登录服务器邮件
server.send_mail(address,info)  发送邮件
server.get_latest() 获取最新接收邮件


发送的消息以字典发送,包含的key:


1、subject 邮件主题

2、from 发送人

3、content_text 邮件内容-文本

4、content_html 邮件内容-HTML

5、attachments 邮件内容-附件,可写多个


代码

# pip install zmail
import zmail
def send_text():
  # 登录邮箱
  server = zmail.server('398707160@qq.com','spcdwgqkltjsbiah')
  # 编写内容
  info = {
    'from':'Zmail',
    'subject':'测试zmail模块',
    'content_text':'这个是zmail邮件信息'
 }
  # 发送邮件
 server.send_mail('hotelmail@126.com',info)
def send_html():
  # 登录邮箱
  server = zmail.server('398707160@qq.com','spcdwgqkltjsbiah')
  # 编写内容
  info = {
    'from':'Zmail',
    'subject':'测试zmail模块',
    'content_html':'<h1>这个是zmail邮件信息</h1>'
 }
  # 发送邮件
 server.send_mail('hotelmail@126.com',info)
def send_file():
  # 登录邮
  server = zmail.server('398707160@qq.com','spcdwgqkltjsbiah')
  # 编写内容
  info = {
    'from':'Zmail',
    'subject':'测试zmail模块',
    'content_html':'<h1>这个是zmail邮件信息</h1>',
    'attachments': [r'.\base_data\backg.jpg']
 }
  # 发送邮件
 server.send_mail('hotelmail@126.com',info
def get_email():
  # 登录邮箱
  server = zmail.server('398707160@qq.com','tzteewnmyfqacbce')
  email = server.get_latest()
  print(email.get('subject'))
  print(email.get('from'))
  print(email.get('content_html'))
  print(email.get('content_text'))
if __name__ == '__main__':
  # send_text()
  # send_html()
  # send_file()
  get_email()
目录
相关文章
|
21天前
|
存储 算法 API
【01】整体试验思路,如何在有UID的情况下获得用户手机号信息,python开发之理论研究试验,如何通过抖音视频下方的用户的UID获得抖音用户的手机号-本系列文章仅供学习研究-禁止用于任何商业用途-仅供学习交流-优雅草卓伊凡
【01】整体试验思路,如何在有UID的情况下获得用户手机号信息,python开发之理论研究试验,如何通过抖音视频下方的用户的UID获得抖音用户的手机号-本系列文章仅供学习研究-禁止用于任何商业用途-仅供学习交流-优雅草卓伊凡
139 82
|
13天前
|
存储 API 数据安全/隐私保护
【02】整体试验思路,在这之前我们发现sec_uid,sec_uid是什么和uid的关系又是什么?相互如何转换?python开发之理论研究试验,如何通过抖音视频下方的用户的UID获得抖音用户的手机号-本系列文章仅供学习研究-禁止用于任何商业用途-仅供学习交流-优雅草卓伊凡
【02】整体试验思路,在这之前我们发现sec_uid,sec_uid是什么和uid的关系又是什么?相互如何转换?python开发之理论研究试验,如何通过抖音视频下方的用户的UID获得抖音用户的手机号-本系列文章仅供学习研究-禁止用于任何商业用途-仅供学习交流-优雅草卓伊凡
51 6
|
13天前
|
C语言 Python
Python学习:内建属性、内建函数的教程
本文介绍了Python中的内建属性和内建函数。内建属性包括`__init__`、`__new__`、`__class__`等,通过`dir()`函数可以查看类的所有内建属性。内建函数如`range`、`map`、`filter`、`reduce`和`sorted`等,分别用于生成序列、映射操作、过滤操作、累积计算和排序。其中,`reduce`在Python 3中需从`functools`模块导入。示例代码展示了这些特性和函数的具体用法及注意事项。
|
21天前
|
Python
python pandas学习(一)
该代码段展示了四个主要操作:1) 删除指定列名,如商品id;2) 使用正则表达式模糊匹配并删除列,例如匹配订单商品名称1的列;3) 将毫秒级时间戳转换为带有时区调整的日期时间格式,并增加8小时以适应本地时区;4) 将列表转换为DataFrame后保存为Excel文件,文件路径和名称根据变量拼接而成。
24 3
|
3月前
|
Python 容器
Python学习的自我理解和想法(9)
这是我在B站跟随千锋教育学习Python的第9天,主要学习了赋值、浅拷贝和深拷贝的概念及其底层逻辑。由于开学时间紧张,内容较为简略,但希望能帮助理解这些重要概念。赋值是创建引用,浅拷贝创建新容器但元素仍引用原对象,深拷贝则创建完全独立的新对象。希望对大家有所帮助,欢迎讨论。
|
3月前
|
Python
Python学习的自我理解和想法(10)
这是我在千锋教育B站课程学习Python的第10天笔记,主要学习了函数的相关知识。内容包括函数的定义、组成、命名、参数分类(必须参数、关键字参数、默认参数、不定长参数)及调用注意事项。由于开学时间有限,记录较为简略,望谅解。通过学习,我理解了函数可以封装常用功能,简化代码并便于维护。若有不当之处,欢迎指正。
|
2月前
|
数据可视化 数据挖掘 大数据
1.1 学习Python操作Excel的必要性
学习Python操作Excel在当今数据驱动的商业环境中至关重要。Python能处理大规模数据集,突破Excel行数限制;提供丰富的库实现复杂数据分析和自动化任务,显著提高效率。掌握这项技能不仅能提升个人能力,还能为企业带来价值,减少人为错误,提高决策效率。推荐从基础语法、Excel操作库开始学习,逐步进阶到数据可视化和自动化报表系统。通过实际项目巩固知识,关注新技术,为职业发展奠定坚实基础。
|
5月前
|
运维 Linux Apache
,自动化运维成为现代IT基础设施的关键部分。Puppet是一款强大的自动化运维工具
【10月更文挑战第7天】随着云计算和容器化技术的发展,自动化运维成为现代IT基础设施的关键部分。Puppet是一款强大的自动化运维工具,通过定义资源状态和关系,确保系统始终处于期望配置状态。本文介绍Puppet的基本概念、安装配置及使用示例,帮助读者快速掌握Puppet,实现高效自动化运维。
112 4
|
9天前
|
机器学习/深度学习 人工智能 运维
基于AI的自动化服务器管理:解锁运维的未来
基于AI的自动化服务器管理:解锁运维的未来
54 0
|
2月前
|
机器学习/深度学习 人工智能 运维
基于AI的自动化事件响应:智慧运维新时代
基于AI的自动化事件响应:智慧运维新时代
134 11