基于模板替换的word文档自动生成

简介

word文档自动生成程序是一个根据用户提供的模板word文档以及一些必要的数据文件来渲染生成所要的word文档的工具。

关键词:批量word文档生成、word文档渲染、自动生成word

使用场景

几种典型的可以采用该工具减少工作量和增加效率的场景。

(1)需要批量生成大量内容基本相同,仅少数信息有差别的word文档。例如生成大量员工的合同、工资单等;

(2)需要在word文档中插入某种指定的大量的数据,手动插入这些数据非常耗时;

(3)需要多次生成一类word文档,每次的word文档仅指定的数据内容改变,其他总体格式保持不变;

(4)根据实验数据等生成word报告,实验数据会发生变化,报告内容大体不变,每次有新的实验数据就需要重新写word报告;

(5)需要在word报告中批量插入大量的图片或者表格,图片在单独的目录下能按规则准备好,或者表格中的数据在excel中已经准备好。

使用方法

用户准备word模板文件,并命名为template.docx

用户编写标签-内容文件,命名为labels.txt

将所有的附加依赖的数据文件,以及template.docx和labels.txt全部放在工作目录下

cmd窗口中执行程序

autoWord.exe 工作目录

例如执行程序所给样例:通用示例

在autoWord.exe程序和通用示例文件夹在同一个目录的情况下,在命令行窗口中执行

autoWord.exe  通用示例

或者指定通用示例文件夹所在的绝对路径

autoWord.exe  C:\\mytest\通用示例

由于本程序在命令行窗口中执行,无需界面操作,因此可供开发者在程序中调用,实现批量自动调用该工具。

本程序提供了多个样例供参考使用,参照用例的labels.txt和template.docx以及生成的product.word可以快速理解使用方法。

关于标签-内容文件labels.txt

它是由用户编写的,记录word中标记的标签,以及数据文件中要替换成的数据内容的文档。

labels.txt的编写需要遵守严格的规则。

关于模板word文档

用户用指定的规则符合在模板word文档中标记一些需要实际替换的文字或图片,表格等数据,这些标记将在程序执行后被替换成labels.txt中指定的内容。

参考样例

word的模板文档样例

详见:(272条消息) word文档-样例1-模板文档_xiyangxiaoguo的博客-CSDN博客

生成的word文档样例

详见:(272条消息) word文档-样例1-结果文档_xiyangxiaoguo的博客-CSDN博客

labels.txt

 如下文档:

#标签--内容对应文档
#==================标签解释======================
#标签不仅可以在Word模板中定义使用,也可以作为中间量在其他的标签中使用
#符号{{}}为内部标记,<>为属性标记,属性标记都是可以缺省的,[]和[[]]为数组标记,()为数组截取部分
##为行注释,#后面的内容将不被读取,常用于忽略某个标签
#:标签名 表示引用一个已经定义的标签的内容
#:.结构体成员名 表示引用一个结构体的某个成员的内容
#=值 表示使用一个具体的值

#以下标签头为特定含义的标签,用户需要严格遵循其语义使用
#image_**表示图片类标签
#array_**表示数组类标签
#pageSeparatedTable_**长表格标签
#table_**普通表格标签
#struct_** 多种复合内容块标签
#-----------------------------------------------

#普通文字替换标签
title={{机械工业}}
testSentence={{当前语句将放入目标文档标记处}}
tableCaption1={{核天体物理学}}
header={{核反应率}}
absorb1={{核燃料1}}
absorb2={{核燃料2}}
struct1={{核反应堆1}}
struct2={{核反应堆2}}
what={{中子}}
who={{光子}}
para2={{中子通量密度}}
subpara2={{核反应率}}
subsubpara2={{多普勒效应或多普勒展宽}}
dopulo={{多普勒展宽}}
alada={{pg,yd}}
zhoudeshi={{lualu}}
id={{100}}
chibu={{xxxxxxxxxx
yyyyyyyyyy}}
caption_label1={{这是一个行数目非常多的表格}}

#图片标签
#属性标签:height图片高度,width图片宽度
image_xx={{chart.png}}
image_yy={{chart.png}}
imageCaption_yy={{这是一个自动插入的图题注}}

#数组类型的数据
array_xx={{[['baba','caca','dili'],[1,2,3],[4,5,6],[1,2,3],[4,5,6],[1,2,3],[4,5,6],[1,2,3],[4,5,6]]}}
array_h1={{['baba','caca','dili']}}
array_h2={{['序号','苹果','梨']}}

#文件类型的数据
#文件类型的数据将自动读取出来并且把内容转化为普通文本标签,数组等类型
file_xx={{xyz.csv}} #csv和xlsx格式的文件将读取成为二维的数组类型
file_xyz={{xyz.xlsx}}

array_mp={{:file_xx}}

#长表格标签--长表格需要将表格拆解成多页,每页单独一个题注
#属性标签:horizontal_header水平表头,vertical_header垂直表头,caption题注,rows_perPage每页的行限制,usePageIndex使用分页指引(1/10)-当前页/总共页
pageSeparatedTable_xx={{:array_xx}}
#普通表格标签
table_xx={{:array_xx}}

table_reflect={{:array_xx}}
array_mab={{:array_mp}}
#用array_**类型去存信息
array_kids={{[['这是第一个子表格','chart.png','图1','zhanghong','2023-01','PJ-RBDD'],['这是第一个子表格','chart.png','图2','liming','2023-01','PJ-RBDX']]}}
array_mem={{['label','image_1','title','author','date','code']}}

#用struct_**类型去解析复合的内容块信息
#属性标签:members内容块的项目成员,
#对于项目成员中的类型为图片的,请使用image_开头的名字作为该项目成员的名字,如image_apple
struct_kids={{:array_kids}} #用户可以在Word文档中通过 struct_kids.label去使用相应内容块的子内容

程序获取地址

链接:https://pan.baidu.com/s/1RXA5JzUb9fmB-EnwFWd8CA?pwd=ptty 
提取码:ptty

你可能感兴趣的:(批量word文档生成,word文档渲染,自动生成word)