Freemarker - 根据模板动态生成word文档

Freemarker 根据模板动态生成word文档

Freemarker 介绍:

  FreeMarker是一个用Java语言编写的模板引擎,它基于模板来生成文本输出,word,html等等。
本篇博客简单介绍根据模板生成word。

Freemarker 使用:

1. Maven工程添加依赖

        <dependency>
            <groupId>org.freemarker</groupId>
            <artifactId>freemarker</artifactId>
            <version>2.3.28</version>
        </dependency>

2. 构建文件模板:
将需要动态填充的内容用 ${} 代替

  • 新建一个word文件:
    在这里插入图片描述

    • 将word文件另存为xml格式的文件:
      这时候需要将动态的填充的数据,使用 ${} 进行代替,如将pentiumCM
      和程序员使用 ${user}, ${job}代替。本人推荐将这个xml文件放到 idea 进行格式化(ctrl + Alt + L)之后再修改
      在这里插入图片描述
      在这里插入图片描述在这里插入图片描述
    • 将修改好的 xml文件 直接修改文件后缀名为:.ftl
      在这里插入图片描述

至此,便得到文件模板。
网上有很多教程,是说在起初的word里面直接将需要动态填充的数据用 ${} 替换,然后另存为xml文件,本人尝试过这种方法是不可行的,这种方法另存为的xml文件中, ${}已经被分开,程序是无法匹配上的。

  1. 代码实现:
    public void genFile() throws Exception {
        // 1:创建Configuration对象,参数是freemarker对应的版本号。
        Configuration configuration = new Configuration(Configuration.getVersion());
        // 2:设置模板文件所在的路径。
        configuration.setDirectoryForTemplateLoading(new File("F:/project/postGradProj/smarthealth/code/gitee/smarthealth/smarthealth/jeecg-boot-base-common/src/main/resources/templates"));
        // 3:设置模板文件使用的字符集。一般就是utf-8.
        configuration.setDefaultEncoding("utf-8");
        // 4:加载模板文件,创建模板对象。
        Template template = configuration.getTemplate("模板文件.ftl");
        // 5:创建模板使用的数据集,可以是pojo也可以是map。一般是Map。
        Map<String, Object> dataModel = new HashMap<>();
        // 向数据集中添加数据
        dataModel.put("user", "pentiumCM(FreeMarker生成)");
        dataModel.put("job", "coder(FreeMarker生成)");
        // 6:创建一个Writer对象,一般创建一FileWriter对象,指定生成的文件名。
        Writer out = new FileWriter(new File("D:/动态生成的word.doc"));
        // 7:调用模板对象的process方法输出文件。
        template.process(dataModel, out);
        // 第八步:关闭流。
        out.close();
    }

效果:
在这里插入图片描述
freemarker还有很多其他功能,本篇博客主要目的给大家介绍一下freemarker的大致流程,详细其他用法需继续百度。

freemarker加载模板目录的方法

Freemarker提供了3种加载模板目录的方法。 它使用Configuration类加载模板。

三种方法分别是:

public void setClassForTemplateLoading(Class clazz, String pathPrefix);
public void setDirectoryForTemplateLoading(File dir) throws IOException;
public void setServletContextForTemplateLoading(Object servletContext, String path);
  1. 第一种:基于类路径,HttpWeb包下的framemaker.ftl文件
    configuration.setClassForTemplateLoading(this.getClass(), “/HttpWeb”);
    configuration.getTemplate(“framemaker.ftl”); //framemaker.ftl为要装载的模板

  2. 第二种:基于文件系统
    configuration.setDirectoryForTemplateLoading(new File(“D:/template”))
    configuration.getTemplate(“framemaker.ftl”); //framemaker.ftl为要装载的模板

  3. 第三种:基于Servlet Context,指的是基于WebRoot下的template下的framemaker.ftl文件
    HttpServletRequest request = ServletActionContext.getRequest();
    configuration.setServletContextForTemplateLoading(request.getSession().getServletContext(), “/template”);
    configuration.getTemplate(“framemaker.ftl”); //framemaker.ftl为要装载的模板

参考资料

https://www.jianshu.com/p/20fd71b2e6a0
https://blog.csdn.net/erpenggg/article/details/81216386

SpringBoot_Freemarker生成Word_多个表格+两层嵌套循环; 步骤说明: 1.用Microsoft Office Word打开word原件;将文档中需要动态生成的内容,替换为属性名 ${name} 2.另存为,选择保存类型Word 2003 XML 文档(*.xml) 3.用Firstobject free XML editor打开文件,选择Tools下的Indent【或者按快捷键F8】格式化文件内容。左边是文档结构,右边是文档内容; 4. 文档生成后有时需要手动修改,查找第一步中设置的属性名,可能会产生类似${n.....ame}类似的样子,我们将将名字中间的标签删掉,恢复为${name} 5. word模板中有表格,需要循环的位置, 用 标签将第二对 标签(即除表头的w:tr标签后的一对)包围起来 同时表格内的属性例如${name},在这里需要修改为${user.name} (userList是集合在dataMap中的key, user是集合中的每个元素, 类似), 如图: PLUS:若表格之外还有嵌套的循环,也需要用,注意这里的标签不要和某对其他标签交叉,不可以出现这种 6. 标识替换完之后,另存为.ftl后缀文件即可。 代码里是相对有一丢丢复杂的,两层嵌套循环; 总(dataMap) deptName 部门名 list(Table)表的集合 table1(map) table-名字 ${map.table} tableName-中文名 ${map.tableName} columnCount-字段数 ${map.columnCount} recordCount-记录数 ${map.recordCount} listA-List--表格1 map.listA column Model属性——字段名 ${model.column} columnName Model属性——字段中文名 ${model.column} rate Model属性——字段占比 ${model.rate} nullValueCount Model属性——字段空值数 ${model.nullValueCount} listB-List--表格2 map.listB …… listC-List--表格3 map.listC …… table2 table-名字 ${map.table} tableName-中文名 ${map.tableName} columnCount-字段数 ${map.columnCount} recordCount-记录数 ${map.recordCount} listA-List--表格1 map.listA column Model属性——字段名 ${model.column} columnName Model属性——字段中文名 ${model.column} rate Model属性——字段占比 ${model.rate} nullValueCount Model属性——字段空值数 ${model.nullValueCount} listB-List--表格2 map.listB …… listC-List--表格3 map.listC …… table3 ……
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值