01
前言

02
准备工作


03
实战演练
#安装模块
pip install docxtpl
pip install zmail
#导入模板库
from docxtpl import DocxTemplate
import pandas as pd
#导入邮件库
import zmail
import time
#读取数据源
df=pd.read_excel('123邮件合并数据源.xls')
print(df)
#Word邮件合并批量生成录取通知书
for i in range(len(df)):
#以字典形式存储模板中需要更新的关键信息
contxt=dict(df.iloc[i])
#获取姓名,作为文件名
filename=contxt['姓名']
#获取邮箱地址
youxiang=contxt['邮箱']
#打开模板文件
tpl = DocxTemplate('邮件合并模板.docx')
#渲染(更新)模板文件生成新文件
tpl.render(contxt)
#保存文件
tpl.save(filename+'.docx')



终于拿到授权码(Python发送QQ邮件必备参数):

#设置邮件主题
subject='录取通知书'
#设置邮件内容
content='你己被我校录取,请妥善保管通知书,并按时报到!'
#设置邮件附件
attachment=filename+'.docx'
#设置邮件信息
mail={'subject':subject,'content_text':content,'attachments':attachment}
#设置发件邮箱
server = zmail.server('你的@qq.com','你的授权码')
#发送邮件
server.send_mail(youxiang,mail)
time.sleep(2)
print('第'+str(i+1)+'封邮件己发送成功')

04
完整代码
#导入模板库
from docxtpl import DocxTemplate
import pandas as pd
#导入邮件库
import zmail
import time
#读取数据源
df=pd.read_excel('123邮件合并数据源.xls')
print(df)
#生成文件并以附件形式发送到邮箱
for i in range(len(df)):
#以字典形式存储模板中需要更新的关键信息
contxt=dict(df.iloc[i])
#获取姓名,作为文件名
filename=contxt['姓名']
#获取邮箱地址
youxiang=contxt['邮箱']
#打开模板文件
tpl = DocxTemplate('邮件合并模板.docx')
#渲染(更新)模板文件生成新文件
tpl.render(contxt)
#保存文件
tpl.save(filename+'.docx')
#设置邮件主题
subject='录取通知书'
#设置邮件内容
content='你己被我校录取,请妥善保管通知书,并按时报到!'
#设置邮件附件
attachment=filename+'.docx'
#设置邮件信息
mail={'subject':subject,'content_text':content,'attachments':attachment}
#设置发件邮箱
server = zmail.server('你的@qq.com','你的授权码')
#发送邮件
server.send_mail(youxiang,mail)
time.sleep(2)
print('第'+str(i+1)+'封邮件己发送成功')
print('邮件己全部发送成功')
本文为转账分享&推荐阅读,若侵权请联系后台删除
-------------------------------------
长按识别下方二维码,并关注公众号 ![]()
1.回复“PY”领取1GB Python数据分析资料
2.回复“BG”领取3GB 名企数据分析报告

