2025年4月14日 星期一 批量生成劳动合同PY代码

一颗大白菜7个月前我的技能264

第一步:

建立劳动合同文档模板。

image.png

第二步:

整理表格数据。

image.png

第三步:

image.png

第四步:

查看文件

image.png

import tkinter as tk
from tkinter import filedialog, messagebox
from openpyxl import load_workbook
import os
import threading
from docx import Document


class WordDocumentGenerator:
    def __init__(self, root):
        self.root = root
        self.root.geometry("800x800")
        self.excel_file = None
        self.word_template = None
        self.output_dir = None
        self.stop_flag = False
        self.create_folders = tk.BooleanVar()
        self.prefix = tk.StringVar()
        self.suffix = tk.StringVar()
        self.selected_fields = []
        font_style = ("微软雅黑", 12)

        # 创建 GUI 组件
        tk.Label(root, text="选择 Excel 文件", font=font_style).pack(pady=10)
        self.excel_path_label = tk.Entry(root, width=50, state="readonly", font=font_style)
        self.excel_path_label.pack(pady=5)
        tk.Button(root, text="浏览", command=self.select_excel_file, font=font_style).pack(pady=5)

        tk.Label(root, text="选择 Word 模板", font=font_style).pack(pady=10)
        self.word_path_label = tk.Entry(root, width=50, state="readonly", font=font_style)
        self.word_path_label.pack(pady=5)
        tk.Button(root, text="浏览", command=self.select_word_template, font=font_style).pack(pady=5)

        tk.Label(root, text="选择输出目录", font=font_style).pack(pady=10)
        self.output_dir_label = tk.Entry(root, width=50, state="readonly", font=font_style)
        self.output_dir_label.pack(pady=5)
        tk.Button(root, text="浏览", command=self.select_output_directory, font=font_style).pack(pady=5)

        tk.Checkbutton(root, text="创建文件夹", variable=self.create_folders, font=font_style).pack(pady=10)

        tk.Label(root, text="前缀:", font=font_style).pack(pady=5)
        tk.Entry(root, textvariable=self.prefix, font=font_style).pack(pady=5)

        tk.Label(root, text="后缀:", font=font_style).pack(pady=5)
        tk.Entry(root, textvariable=self.suffix, font=font_style).pack(pady=5)

        tk.Button(root, text="生成 Word 文档", command=self.generate_word_docs, font=font_style).pack(pady=20)
        tk.Button(root, text="停止生成", command=self.stop_generating, font=font_style).pack(pady=10)

    def select_excel_file(self):
        self.excel_file = filedialog.askopenfilename(filetypes=[("Excel files", "*.xlsx;*.xls")])
        if self.excel_file:
            self.excel_path_label.config(state="normal")
            self.excel_path_label.delete(0, tk.END)
            self.excel_path_label.insert(0, self.excel_file)
            self.excel_path_label.config(state="readonly")

    def select_word_template(self):
        self.word_template = filedialog.askopenfilename(filetypes=[("Word files", "*.docx")])
        if self.word_template:
            self.word_path_label.config(state="normal")
            self.word_path_label.delete(0, tk.END)
            self.word_path_label.insert(0, self.word_template)
            self.word_path_label.config(state="readonly")

    def select_output_directory(self):
        self.output_dir = filedialog.askdirectory()
        if self.output_dir:
            self.output_dir_label.config(state="normal")
            self.output_dir_label.delete(0, tk.END)
            self.output_dir_label.insert(0, self.output_dir)
            self.output_dir_label.config(state="readonly")

    def load_excel_fields(self, excel_file):
        workbook = load_workbook(excel_file)
        sheet = workbook.active
        headers = [cell.value for cell in sheet[1]]
        return headers

    def generate_word_docs(self):
        if not self.excel_file or not self.word_template or not self.output_dir:
            messagebox.showerror("错误", "请选择 Excel 文件、Word 模板和输出目录")
            return
        self.stop_flag = False
        threading.Thread(target=self.fill_word_from_excel, args=(
            self.excel_file, self.word_template, self.output_dir, self.create_folders.get(),
            self.prefix.get(), self.suffix.get(), self.load_excel_fields(self.excel_file))).start()

    def stop_generating(self):
        self.stop_flag = True

    def fill_word_from_excel(self, excel_file, word_template, output_dir, create_folders, prefix, suffix,
                             selected_fields):
        workbook = load_workbook(excel_file)
        sheet = workbook.active
        template = Document(word_template)

        for row in sheet.iter_rows(min_row=2, values_only=True):
            if self.stop_flag:
                break
            data = dict(zip(selected_fields, row))
            new_doc = Document(word_template)
            for paragraph in new_doc.paragraphs:
                for key, value in data.items():
                    if key in paragraph.text:
                        for run in paragraph.runs:
                            run.text = run.text.replace(key, str(value))

            if create_folders:
                folder_name = os.path.join(output_dir, f"{prefix}{data.get(selected_fields[0], '')}{suffix}")
                os.makedirs(folder_name, exist_ok=True)
                output_path = os.path.join(folder_name, f"{prefix}{data.get(selected_fields[0], '')}{suffix}.docx")
            else:
                output_path = os.path.join(output_dir, f"{prefix}{data.get(selected_fields[0], '')}{suffix}.docx")
            new_doc.save(output_path)


if __name__ == "__main__":
    root = tk.Tk()
    app = WordDocumentGenerator(root)
    root.mainloop()


免责声明
如果您对本文有异议,请先阅读本站《免责声明》,如仍保持您个人观点可与本人联系。

相关文章

2025年3月12日 星期三 生育津贴计算器

2025年3月12日 星期三 生育津贴计算器

职工单位上年度月平均工资,通常是用单位上年度工资总额除以该单位上年度职工月平均人数得出。假设某单位的情况如下:统计上年度工资总额:把单位上年度所有职工的工资、奖金、津贴、补贴等货币性收入相加。例如,A...

2024年8月27日 星期二 论一次电梯卡的延期 鑫洋V9楼控

2024年8月27日 星期二 论一次电梯卡的延期 鑫洋V9楼控

我老丈母娘家的电梯,每月10元,我还不经常去,月月还得缴纳10元,有点犯不上,自己做一个电梯卡吧。 方便、省事。11扇区 0 区块: EE BE 9B&nbs...

2024年8月30日 星期五 百度收录“优秀经办人”AI 知识库

2024年8月30日 星期五 百度收录“优秀经办人”AI 知识库

百度收录“优秀经办人”智能体,方便我平台用户了解吉林省保险政策及操作流程。如解答不如意,请联系系统管理员,一对一讲诉。AI知识库已接入“你好优秀经办人”微信公众号,也可直接在公众号内发送问题,AI为您...

长春地区 优秀经办人 AI 知识库大模型助力五险一金服务

长春地区 优秀经办人 AI 知识库大模型助力五险一金服务

        本系统由 “百度文心智能体平台” 搭建。文心智能体平台 AgentBuilder,是百度推出的基于文心大...

养老金测算表 吉林省养老金测试 2.5 无限制版(240717).xlsx 最终版

养老金测算表 吉林省养老金测试 2.5 无限制版(240717).xlsx 最终版

吉林省还原《企业职工养老保险基本养老金预核定表》今日再次更新v2.6版本,准确率达到99.8%,为什么不说100%,我谦虚而已!此表只售不送!感谢各企事业单位经办人提供大量参考!次版本不出意外,应该是...

长春五险一金基数及比例2024年7月至2025年6月 (最终公式版).xlsx

长春五险一金基数及比例2024年7月至2025年6月 (最终公式版).xlsx

长春五险一金基数及比例2024年7月至2025年6月 (最终公式版).xlsx为保护作者劳动成果,表格内仅红色区域可编辑,其他地方不可处理。需要密码的经办人可以联系我,很愿意告知。...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

服务热线

18686626826

微信客服

微信客服

2025年度企业稳岗补贴公式查询系统
优秀经办人 AI播客,多元呈现,沉浸体验
吉林省企业职工退休养老金智能核算与服务系统
×