xdocreport word html,使用xdocreport和Freemarker生成word

本文介绍了如何利用Java和Freemarker模板引擎生成Word文档。通过在Word中插入域并使用Freemarker标记,实现变量替换和条件判断。示例包括了变量替换、数组遍历、IF判断以及表格创建等操作,详细阐述了每个步骤和注意事项,为Java开发者提供了实用的Word自动化生成指南。
摘要由CSDN通过智能技术生成

如何使用Java生成Word文档呢?基本的想法就是使用一个现成的Word作为模版,需要用变量替换的地方,在word中使用一种模版语言来标记,然后再使用模版引擎把它替换掉。

具体的思路如图:

4fe00aa02ea2

Free Marker处理模版的方式

Java的code就不贴在这里了,xdocreport中介绍的很详细。然而在word中添加freemarker的地方介绍的好像不是很清楚。笔者经过多次的尝试,总结如下:

1.简单的变量替换

首先要做的是要插入一个域,这个东西不是很常用。在word文档的这个地方。

4fe00aa02ea2

插入域

点击插入域以后,word会弹出一个框来,这里需要选择MERGEFIELD

4fe00aa02ea2

选择MERGEFIELD

现在就可以在域代码提示符**MERGEFILED **后面填写所需的Freemarker标记例如:

MERGEFIELD ${d.lastName}

在Word上面会插入一个标记,如下图所示:

4fe00aa02ea2

在word里面显示的域标记

修改它的时候,需要右键这个域,选择更换域代码,这个时候,这个域会变成这样:

{MERGEFIELD ${d.lastName} \*MERGEFILED}

两边的标记不用管它,我们关注的地方就在中间的这个地方,后面提到的标记都是写在中间的,修改之后,再右键点击更新域。这个域就算更新完成了。

Word中的这些域都会被当成freemarker替换掉,如果语法不对,整个word生成都会失败。

使用Hash表

所需的freemarker标记为:

${d["lastName"]}

所以生成的域代码就是:

{MERGEFIELD ${d["lastName"]} \*MERGEFILED}

数组

这个地方需要几个标记,一个是循环开始,一个循环中的内容,一个循环结束。最终的标记效果如下:

4fe00aa02ea2

遍历一个数组,并显示数组中元素的某些属性

其中前面的标记如下,注意是有双引号的。

"[#list developers as developer]"

后面的标记是:

[/#list]

IF

基本跟Freemarker的相同。也有两个标记。

[#if holder_has_next]

[/#if]

这个IF是判断list中是否还有下一个元素。

一个复杂的例子

例如,我们要实现一个效果,遍历某个对象(agreement)的一个数组属性(holders),数组中的元素是一个Hash表,显示这个Hash表中的某个key值。每个值使用顿号隔开。最终的效果如下:

4fe00aa02ea2

生成的域

每个域代码如下:

"[#list agreement.holders as holder]"

${holder["fullName"]}

[#if holder_has_next]

[/#if]

[/#list]

表格

表格是word里面较为特殊的结构,xdocreport提供了一些方法可以较为简单的生成表格,其中一种方法使用metadata在java中标记某些某些变量是数组,然而这样降低了java code的复用度,对于对象的某些数组属性,还要再将变量注册到freemarker的context中,非常不灵活,所以决定使用不含metadata的方法。

4fe00aa02ea2

表格

需要注意的地方是在表格第一列前后各有一个标记,他们分别是:

"@before-row[#list agreement.holders as h]"

@after-row[/#list]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用XDocReportFreeMarker模板来生成带页数的Word文档。以下是一个示例代码: 1. 添加以下依赖项到您的项目中: ```xml <dependency> <groupId>fr.opensagres.xdocreport</groupId> <artifactId>xdocreport</artifactId> <version>1.0.6</version> </dependency> <dependency> <groupId>fr.opensagres.xdocreport</groupId> <artifactId>xdocreport-template-freemarker</artifactId> <version>1.0.6</version> </dependency> ``` 2. 创建一个FreeMarker模板,包含一个名为“page”的变量,用于显示当前页数。例如,以下是一个简单的模板: ``` <html> <head> <title>My Document</title> </head> <body> <p>Page ${page} of ${nbPages}</p> <p>This is the content of my document.</p> </body> </html> ``` 3. 在Java代码中使用XDocReportFreeMarker模板来填充Word文档。以下是一个示例代码: ```java import java.io.FileOutputStream; import java.io.InputStream; import java.io.OutputStream; import java.util.HashMap; import java.util.Map; import org.apache.poi.xwpf.usermodel.XWPFDocument; import fr.opensagres.xdocreport.core.XDocReportException; import fr.opensagres.xdocreport.core.io.XOutputStream; import fr.opensagres.xdocreport.document.registry.XDocReportRegistry; import fr.opensagres.xdocreport.template.TemplateEngineKind; import fr.opensagres.xdocreport.template.formatter.FieldsMetadata; public class GenerateWordDoc { public static void main(String[] args) { try { // Load the template InputStream in = GenerateWordDoc.class.getResourceAsStream("template.docx"); XWPFDocument document = new XWPFDocument(in); FieldsMetadata metadata = new FieldsMetadata(); metadata.addFieldAsTextStyling("page"); XDocReportRegistry.getRegistry().register(document, metadata, TemplateEngineKind.Freemarker); // Populate the template Map<String, Object> context = new HashMap<>(); context.put("page", "${page}"); context.put("nbPages", "${nbPages}"); OutputStream out = new FileOutputStream("output.docx"); XDocReportRegistry.getRegistry().getReport(document, null).process(context, new XOutputStream(out)); // Close the streams in.close(); out.close(); } catch (Exception e) { e.printStackTrace(); } } } ``` 此代码将使用名为“template.docx”的模板创建一个新的Word文档,并将“page”变量替换为当前页数。请注意,您需要使用FieldsMetadata对象来标识文档中的字段,并将其注册到XDocReportRegistry中。最后,代码将输出生成Word文档到名为“output.docx”的文件中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值