2000字范文,分享全网优秀范文,学习好帮手!
2000字范文 > 【Python办公自动化】根据excel中数据批量生成word文档(适用劳动合同 质检报告 通

【Python办公自动化】根据excel中数据批量生成word文档(适用劳动合同 质检报告 通

时间:2022-03-10 15:25:40

相关推荐

【Python办公自动化】根据excel中数据批量生成word文档(适用劳动合同 质检报告 通

大家在工作中一定经常遇到类似的情况:

1、制作劳动合同表,要从excel表格中将每个人的数据导入到docx劳动合同中,重复量很大。

2、制作XX方案或XX报告,Word文档布局和格式统一,只是需填充的内容信息来源于Excel。

3、制作通知书,从excel表格中将每个人的数据分别填入到docx通知书中。

4、其他各式各样的场景,反正都满足同样的条件,就是:个性化定制多份Word文档,而个性化信息来源于格式统一的Excel。

这次是应同事小伙伴邀约,以及自己之前也遇到过这样的需求,就搞了一个快速生成文档的小程序。这个,非常适合摸鱼大王的风格。

一、代码

参考原帖子没有完整代码,不过提供了很有效的思路,在此感谢。

我在原帖子上加上了循环遍历Excel,以及新增文件夹放置生成文件。下面是可直接执行的完整代码。

from docxtpl import DocxTemplatefrom datetime import datetimeimport time import datetimeimport pandas as pdimport oszpath=os.getcwd()+'\\'# zpath=r'D:\【批量工具_效率工作】\批量_使用Python根据excel中数据批量生成word文件(word文件填空)'+'\\'current_file_path=zpath+r'\文档生成结果'+str(datetime.date.today())try:os.mkdir(current_file_path)except:passtpl = DocxTemplate(zpath+'建大附小家长通知书.docx')#这些字段从csv中获取grade = pd.read_excel(zpath+'成绩单.xlsx')# stid = grade['学号']name = grade['姓名'].str.rstrip() # str.rstrip()用于去掉换行符chinese = grade['语文']math = grade['数学']english = grade['外语']# 遍历成绩单,逐个生成通知书num = grade.shape[0]for i in range(num):context = {"name": name[i],"chinese": chinese[i],"math": math[i],"english": english[i],"date": time.strftime('%Y-%m-%d',time.localtime(time.time())),#"date": {0:%Y}年{0:%m}月{0:%d}日".format(datetime.now()),# "date":time.strftime('%Y-%m-%d',time.localtime(time.time()))# "date": datetime.now(),}tpl.render(context)tpl.save(current_file_path+r"\{}的建大附小家长通知书.docx".format(name[i]))

二、结果

如图:

三、代码所需的模板文件

3.1数据源(xlsx)

成绩单.xlsx (如下)

3.2 文档模板(docx)

docx模板《建大附小家长通知书.docx》如下:

(在需要插值的位置填充 {{}} 表达式)

参考帖子:超简单Python将Excel的指定数据插入到docx模板并生成

/weixin_41133061/article/details/88543432?utm_medium=distribute.pc_relevant_download.none-task-blog-baidujs-4.nonecase&depth_1-utm_source=distribute.pc_relevant_download.none-task-blog-baidujs-4.nonecase

【Python办公自动化】根据excel中数据批量生成word文档(适用劳动合同 质检报告 通知书等应用场景)

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。