Word处理控件Aspose.Words功能演示:如何使用 Java 从模板动态生成 Word 文档

Aspose.Words是一种高级Word文档处理API,用于执行各种文档管理和操作任务。API支持生成,修改,转换,呈现和打印文档,而无需在跨平台应用程序中直接使用Microsoft Word。此外,

Aspose API支持流行文件格式处理,并允许将各类文档导出或转换为固定布局文件格式和最常用的图像/多媒体格式。

Aspose.words 最新下载(qun:761297826)icon-default.png?t=N2N8https://www.evget.com/product/564/download

报告生成过程通常包括填充包含所需字段占位符的预定义文档模板。报告引擎将模板文档作为输入,用数据动态填充占位符并生成结果报告。本文还将展示一个类似的用例,您可以通过使用 Java 以编程方式动态填充 Word 模板来生成 Word 文档。

要从 DOCX 模板生成 Word 文档,我们将使用 Aspose.Words for Java API 提供的 LINQ Reporting Engine。 LINQ 报告引擎支持用于 Word 模板的文本、图像、列表、表格、超链接和书签的各种标记。包含这些标签的模板文档由引擎填充来自 Java 对象以及 XML、JSON 或 CSV 数据源的数据。因此,让我们开始使用 Java 从模板生成 Word 文档。

本文将介绍如何使用以下模板从模板生成 Word 文档:

  • Java 对象的值,
  • XML 数据源,
  • JSON数据源,
  • CSV 数据源。

安装 Aspose.Words for Java - Word 自动化和报告生成 API

您可以下载 Aspose.Words for Java JAR 或使用以下配置将其添加到基于 Maven 的应用程序中。

存储库:

<repository>
<id>AsposeJavaAPI</id>
<name>Aspose Java API</name>
<url>https://repository.aspose.com/repo/</url>
</repository>

依赖:

<dependency>
<groupId>com.aspose</groupId>
<artifactId>aspose-words</artifactId>
<version>20.1</version>
<type>pom</type>
</dependency>

使用 Java 对象从模板生成 Word 文档

要开始生成报告,我们首先通过使用 Java 对象中的值填充模板来创建一个 Word 文档。为了定义文档模板,创建一个新的 Word 文档,插入以下标签并将其保存为 DOCX 文档。

<<[s.getName()]>> says: "<<[s.getMessage()]>>."

在上面的模板中,“s”将被视为 Java 类的对象,用于填充标签。因此,让我们创建一个名为 Sender 的类,其中包含两个数据成员。

public class Sender {
public Sender(String name, String message) {
_name = name;
_message = message;
}
public String getName() {
return _name;
}
public String getMessage() {
return _message;
}
private String _name;
private String _message;
}

现在,是时候将 Word 模板传递给 LINQ 报告引擎并根据 Sender 对象的值生成 Word 文档了。以下是生成Word文档的步骤:

  • 创建 Document 对象并使用模板的路径对其进行初始化。
  • 创建并初始化 Sender 类的对象。
  • 创建一个 ReportingEngine 类的对象。
  • 使用接受文档模板、数据源和数据源名称的 ReportingEngine.buildReport() 方法构建报表。
  • 使用 Document.save() 方法保存生成的 Word 文档。

以下代码示例展示了如何使用 Java 对象的值从 Word 模板生成 Word 文档。

// 创建 Document 对象并使用 DOCX 模板进行初始化。
Document doc = new Document("template.docx");
// 创建发件人对象。
Sender sender = new Sender("LINQ Reporting Engine", "Hello World");
// 创建 ReportingEngine 对象。
ReportingEngine engine = new ReportingEngine();
// 建立报告。
engine.buildReport(doc, sender, "s");
// 另存为 Word 文档。
doc.save("word.docx");

输出

使用 XML 数据从模板创建 Word 文档

现在让我们更进一步,看看如何在有点复杂的场景中使用 XML 数据源填充 Word 模板。以下是我们将用于填充 Word 模板的 XML 数据源。

<Persons>
<Person>
<Name>John Doe</Name>
<Age>30</Age>
<Birth>1989-04-01 4:00:00 pm</Birth>
</Person>
<Person>
<Name>Jane Doe</Name>
<Age>27</Age>
<Birth>1992-01-31 07:00:00 am</Birth>
</Person>
<Person>
<Name>John Smith</Name>
<Age>51</Age>
<Birth>1968-03-08 1:00:00 pm</Birth>
</Person>
</Persons>

在这种情况下,我们将在模板文档中为 XML 数据源中的多条记录使用以下标记。

<<foreach [in persons]>>Name: <<[Name]>>, Age: <<[Age]>>, Date of Birth: <<[Birth]:"dd.MM.yyyy">>
<</foreach>>
Average age: <<[persons.average(p => p.Age)]>>

在这种情况下,用于生成 Word 文档的 Java 代码是相同的,除了将 Java 对象作为数据源传递之外,我们将在 ReportingEngine.buildReport() 方法中传递 XmlDataSource 对象。以下代码示例展示了如何通过使用 Java 中的 XML 数据源填充文档模板来创建 Word 文档。

// 创建 Document 对象并使用 DOCX 模板进行初始化。
Document doc = new Document("template.docx");
// 加载 XML
XmlDataSource dataSource = new XmlDataSource("./datasource.xml");
// 创建 ReportingEngine 对象。
ReportingEngine engine = new ReportingEngine();
// 建立报告。
engine.buildReport(doc, dataSource, "persons");
// 另存为 Word 文档。
doc.save("word.docx");

输出

使用 JSON 数据从模板生成 Word 文档

现在让我们看看如何使用 JSON 数据源从 DOCX 模板生成 Word 文档。以下是我们将在此示例中使用的 JSON 数据。

[
{
Name: "John Smith",
Contract:
[
{
Client:
{
Name: "A Company"
},
Price: 1200000
},
{
Client:
{
Name: "B Ltd."
},
Price: 750000
},
{
Client:
{
Name: "C & D"
},
Price: 350000
}
]
},
{
Name: "Tony Anderson",
Contract:
[
{
Client:
{
Name: "E Corp."
},
Price: 650000
},
{
Client:
{
Name: "F & Partners"
},
Price: 550000
}
]
},
]

在此示例中,我们将生成 Word 文档,其中包含按经理分组的客户列表。根据这种情况,DOCX 模板将如下所示:

<<foreach [in managers]>>Manager: <<[Name]>>
Contracts:
<<foreach [in Contract]>>- <<[Client.Name]>> ($<<[Price]>>)
<</foreach>>
<</foreach>>

为了加载 JSON 数据源,Aspose.Words 提供了 JsonDataSource 类。以下代码示例展示了如何使用 Java 中的 JSON 数据源从模板创建 Word 文档。

// 创建 Document 对象并使用 DOCX 模板进行初始化。
Document doc = new Document("template.docx");
// 加载 JSON
JsonDataSource dataSource = new JsonDataSource("datasource.json");
// 创建 ReportingEngine 对象。
ReportingEngine engine = new ReportingEngine();
// 建立报告。
engine.buildReport(doc, dataSource, "managers");
// 另存为 Word 文档。
doc.save("word.docx");

输出

使用 CSV 数据从模板生成 Word 文档

最后但同样重要的是,让我们看看如何通过使用以下 CSV 数据源填充 Word 模板来生成 Word 文档。

John Doe,30,1989-04-01 4:00:00 pm
Jane Doe,27,1992-01-31 07:00:00 am
John Smith,51,1968-03-08 1:00:00 pm

本示例将使用以下 Word 模板:

<<foreach [in persons]>>Name: <<[Column1]>>, Age: <<[Column2]>>, Date of Birth: <<[Column3]:"dd.MM.yyyy">>
<</foreach>>
Average age: <<[persons.average(p => p.Column2)]>>

为了处理 CSV 数据源,Aspose.Words 提供了 CsvDataSource 类。以下代码示例展示了如何使用 Java 中的 CSV 数据源生成 Word 文档。

// 创建 Document 对象并使用 DOCX 模板进行初始化。
Document doc = new Document("template.docx");
// 加载 CSV
CsvDataSource dataSource = new CsvDataSource("datasource.csv");
// 创建 ReportingEngine 对象。
ReportingEngine engine = new ReportingEngine();
// 建立报告。
engine.buildReport(doc, dataSource, "persons");
// 另存为 Word 文档。
doc.save("word.docx");

输出

以上便是如何使用 Java 从模板动态生成 Word 文档的过程,要是您还有其他关于产品方面的问题,欢迎咨询我们,或者加入我们官方技术交流群

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
“com.aspose.words.filecorruptedexception: the document appears to be corrupte” 是一个在使用Aspose.Words操作文档时可能会遇到的异常错误。这个错误表示文档看起来是损坏的。 当我们使用Aspose.Words处理文档时,可能会发生一些不可预料的问题。如果文档的结构或内容不符合Aspose.Words所期望的格式,就会引发“文件损坏异常”。这可能是因为文档本身已经损坏或损坏,或者文档格式不符合Aspose的规范要求。 要解决这个问题,可以尝试以下几个方案: 1. 确保你的Aspose.Words的版本是最新的。有时候这个问题可能是由于旧版本的Aspose.Words引起的,更新到最新版本可能会解决该问题。 2. 检查文档本身是否损坏。你可以尝试使用其他文档查看器或编辑器打开该文档,看是否可以正常访问。如果是损坏的,那么你可能需要找到一个可用的备份文件。 3. 检查文档的格式是否符合Aspose.Words的要求。Aspose.Words文档的格式和内容有一些特定的要求,例如支持的文件类型、支持的文档版本等。确保你的文档符合Aspose.Words的要求,如果不符合,可以尝试转换文档格式或升级文档版本。 4. 如果以上方法仍然无法解决问题,可以联系Aspose的技术支持团队,向他们提供详细的错误信息和问题描述,以便他们能够更深入地帮助解决。 总之,“com.aspose.words.filecorruptedexception: the document appears to be corrupte” 这个异常表示文档看起来是损坏的,可能是由于文档本身损坏或格式不符合Aspose.Words的要求所致。通过更新Aspose.Words版本、检查文档的完整性和格式,或与Aspose的技术支持团队联系,我们有望解决该问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值