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('邮件合并成功')
合并结果

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

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

薛定谔_51

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

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

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

打赏作者

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

抵扣说明:

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

余额充值