使用word批量制作证书,发现制作好人证书单个保存时有点麻烦, 特用python实现批量修改word文本框内容,生成单个word文件。
本代码段中涉及word文档包含一张底图图片,及两个文本框。其他童鞋有需要修改多个文本框内容的,可依次添加。
# 导入包
import osimport time
from threading import Thread
import pythoncom
import win32com.client
from openpyxl import load_workbook
# 声明 doc 之前要加入的代码
pythoncom.CoInitialize()
# 模拟打开office
word = win32com.client.Dispatch('Word.Application')
# 后台运行
word.Visible = False
if not os.path.exists('批量创建word证书'):
os.mkdir('批量创建word证书')
# 加载证书明细
wb = load_workbook("data.xlsx")
old_text1 = sheet.cell(row=1, column=1).value
old_text2 = sheet.cell(row=1, column=2).value
# 文本框替换函数
def text_box_replace(start_num, end_num):
for row in range(start_num, end_num):
# 打开模板文件
doc = word.Documents.Open(r"模板.docx")
# 读取需要替换的值
new_text1 = sheet.cel