python实现word邮件合并

15 篇文章 2 订阅
5 篇文章 0 订阅

众所周知word/WPS中的邮件合并功能可以根据word模板从excel表格中读取数据,进而生成不同的文件,但是邮件合并也有其缺陷,那就是每次合并数据都需操作插入合并域,如果经常需要根据数据生成固定模板word文件,那么就显得很麻烦

利用程序固定数据替换模式,需要生成文件时可以一键操作就极为方便

工具:python解释器,xlrd包(Excel数据读取),docx-mailmerge包(邮件合并包)
docx-mailmerge仅支持docx格式文件
2种文件生成方式:合并到同一新文件,合并到不同新文件

首先制作邮件合并模板

在这里插入图片描述
在这里插入图片描述
域名可以使用中文
最终完成的word模板,wps操作步骤类似
在这里插入图片描述

excel数据

在这里插入图片描述

导入python模块
import os.path
import xlrd
from mailmerge import MailMerge
python代码,合并到同一新文件
def merge_1():
    """
    word邮件合并到同一新文件,word、wps模板均可
    根据Excel每行数据生成单个同一模板word文件
    """
    docx = r'E:\测试\证明-模板.docx'
    xlsx = r'E:\测试\证明数据.xlsx'
    filepath = os.path.dirname(docx)
    wb = xlrd.open_workbook(xlsx)
    ws = wb.sheet_by_index(0)
    nrow = ws.nrows
    list_temp = []  # 空列表

    for key in range(1, nrow):
        dict_temp = {}  # 空字典
        dict_temp['name'] = str(ws.cell_value(key, 1))
        dict_temp['position'] = str(ws.cell_value(key, 2))
        list_temp.append(dict_temp)
    with MailMerge(docx) as doc:
        doc.merge_templates(list_temp, separator='page_break')
        output = r'E:\测试\证明文件.docx'
        doc.write(output)
    print('邮件合并成功')
python代码,合并到不同新文件
def merge_2():
    """
    word邮件合并到不同新文件,word、wps模板均可
    根据Excel每行数据生成多个同一模板word文件
    """
    docx = r'E:\测试\证明-模板.docx'
    xlsx = r'E:\测试\证明数据.xlsx'
    filepath = os.path.dirname(docx)
    wb = xlrd.open_workbook(xlsx)
    ws = wb.sheet_by_index(0)
    nrow = ws.nrows

    for key in range(1, nrow):
        with MailMerge(docx) as doc:
            doc.merge(name = str(ws.cell_value(key, 1)),
                position = str(ws.cell_value(key, 2)))
            output = filepath + r'\证明-{}.docx'.format(str(ws.cell_value(key, 1)))
            doc.write(output)
    print('邮件合并成功')
合并结果

在这里插入图片描述
在这里插入图片描述

  • 8
    点赞
  • 48
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
邮件合并是指将一封邮件发送给多个收件人,但是每个收件人看到的邮件内容都不同,通常是根据收件人的信息自动填充邮件内容中的某些字段。 在 Python实现邮件合并功能,可以使用第三方库 `smtplib` 和 `email`。以下是一个简单的邮件合并示例: ```python import smtplib from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart # 收件人列表 to_list = ['[email protected]', '[email protected]'] # 邮件正文模板,可以用占位符 {} 代替需要填充的内容 template = 'Dear {},\n\nThis is a test email. Best regards,\nYour Name' # 发送邮件的邮箱和密码 sender = '[email protected]' password = 'your_email_password' # SMTP 服务器地址和端口 smtp_server = 'smtp.example.com' smtp_port = 587 # 登录邮箱 server = smtplib.SMTP(smtp_server, smtp_port) server.starttls() server.login(sender, password) # 循环发送邮件 for to_addr in to_list: # 构造邮件正文 message = MIMEMultipart() message['From'] = sender message['To'] = to_addr message['Subject'] = 'Test Email' body = MIMEText(template.format(to_addr.split('@')[0]), 'plain') message.attach(body) # 发送邮件 server.sendmail(sender, to_addr, message.as_string()) # 关闭连接 server.quit() ``` 在上面的代码中,我们首先定义了收件人列表和邮件正文模板。然后,我们使用 `smtplib` 和 `email` 库构造邮件正文,并循环发送邮件给每个收件人。在发送邮件之前,我们需要登录邮箱,并指定 SMTP 服务器的地址和端口。最后,我们关闭连接并退出程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

薛定谔_51

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值