当前位置: 首页 > article >正文

Python 批量生成Word 合同

要使用 Python 批量生成 Word 合同,您可以遵循以下步骤:

1. 整理 Excel 数据

假设您有一个 Excel 文件,其中第一行为字段名称,下面是对应的内容。举个例子,Excel 数据如下:

姓名地址电话日期
张三北京市某街道138001380002025-01-07
李四上海市某街道139001390002025-01-08

2. 准备合同模版

您需要一个 Word 合同模板,其中包含需要替换的占位符。假设您的合同模板 (contract_template.docx) 是一个 Word 文件,里面有类似 {{姓名}}{{地址}}{{电话}}{{日期}} 的占位符。

3. Python 脚本

以下是一个 Python 脚本的示例,使用 pandas 读取 Excel 数据,python-docx 操作 Word 文档:

安装所需的库
pip install pandas openpyxl python-docx
Python 脚本
import pandas as pd
from docx import Document
import os

# 读取 Excel 文件
excel_file = 'contracts.xlsx'  # 替换为你的 Excel 文件路径
df = pd.read_excel(excel_file)

# 合同模版路径
template_path = 'contract_template.docx'  # 替换为你的 Word 模版文件路径

# 输出文件夹
output_dir = 'generated_contracts'
os.makedirs(output_dir, exist_ok=True)

# 函数:根据数据替换模板中的字段
def generate_contract(data_row, template_path, output_path):
    # 读取合同模版
    doc = Document(template_path)
    
    # 遍历文档中的所有段落,替换占位符
    for para in doc.paragraphs:
        for key, value in data_row.items():
            para.text = para.text.replace(f'{{{{ {key} }}}}', str(value))
    
    # 保存生成的合同
    doc.save(output_path)

# 遍历 Excel 数据,并生成合同
for index, row in df.iterrows():
    # 获取每行数据
    data_row = row.to_dict()

    # 合同输出路径
    output_path = os.path.join(output_dir, f'contract_{index + 1}.docx')
    
    # 生成合同
    generate_contract(data_row, template_path, output_path)

    print(f'合同 {index + 1} 已生成: {output_path}')

print("所有合同生成完毕!")
代码解释:
  1. 读取 Excel 数据:使用 pandas.read_excel() 读取 Excel 文件并转换为 DataFrame,确保 Excel 的第一行是字段名。
  2. 合同模版替换:使用 python-docx 打开 Word 模板文件,并通过替换文档中各段落的占位符(如 {{姓名}})来填充数据。
  3. 保存文件:将修改后的 Word 文件保存到指定的输出目录,每个文件以 contract_{index}.docx 命名。

4. 流程

  • 准备一个包含数据的 Excel 文件,字段名称与合同模板中的占位符相匹配。
  • 编写并运行 Python 脚本,生成每个合同。
  • 输出文件将保存在 generated_contracts 文件夹中。

更多定制化需求,接需求:

signmaker AI Contract Generator 智能定制化合同


http://www.kler.cn/a/472311.html

相关文章:

  • 如何监控批量写入的性能瓶颈?
  • Vue进阶(贰幺叁)node 版本切换
  • 【QT】增删改查 XML 文件的类
  • Clisoft SOS与CAD系统集成
  • 【游戏设计原理】53 - 解决问题的障碍
  • 基于SpringBoot的斯诺克球馆预约购票管理系统
  • xss-labs(level11-20)【通关技巧】
  • el-table 使用el-form 表单验证
  • STM32学习(十)
  • 嵌入式入门Day38
  • Android Process 问题:NoSuchMethodError,No static method myProcessName()
  • HTML5实现好看的博客网站、通用大作业网页模板源码
  • 第19章 数据库备份与恢复
  • 基于单片机的观赏类水草养殖智能控制系统的设计(论文+源码)
  • 采用标准化的方式开展设计-研发中运用设计模式
  • 中国科技统计年鉴EXCEL版(2021-2023年)-社科数据
  • SAP 01-初识AMDP(ABAP-Managed Database Procedure)
  • 一种用于无人机任务卸载的轻量级深度强化学习框架
  • Android系统默认开启adb root模式
  • npm发布自定义包
  • Cannot run program “docker“: CreateProcess error=2,系统找不到指定的文件
  • 深度强化学习中SAC算法:数学原理、网络架构及其PyTorch实现
  • 基于Python的音乐播放器 毕业设计-附源码73733
  • redis Redis内存缓存过期机制
  • 【网络安全设备系列】9、WAF(Web应用防火墙)
  • python无需验证码免登录12306抢票 --selenium(2)