Apose.words 功能集成示例

系列文章目录



前言

本文是 Apose.words 的一些常用功能的集成示例。


一、基本功能

1. word 文档合并

// 获取文档
Document doc1 = new Document("D:/doc1.docx");
Document doc2 = new Document("D:/doc2.docx");

// 将文档2追加到文档1(保留原格式)
doc1.appendDocument(document2, ImportFormatMode.KEEP_SOURCE_FORMATTING);

// 保存文档
doc1.save("D:/doc.docx");

二、个性化功能

1. 限制仅标签可编辑

限制文档编辑,并设置可编辑区域:

// 加载文档
Document doc = new Document("E:/test.docx");
// 设置只读
doc.protect(ProtectionType.READ_ONLY, "123456");

DocumentBuilder builder = new DocumentBuilder(doc); // 文档指针
// 获取所有标签
BookmarkCollection bookmarks = doc.getRange().getBookmarks();
// 循环所有标签
for (int i = 0; i < bookmarks.getCount(); i++) {
    Bookmark bookmark = bookmarks.get(i);
    builder.moveToBookmark(bookmark.getName(), true, true);
    builder.write(" "); // 插入空格,防止用户编辑清除标签内容时将文档标签也删除
    // 设置可编辑区域
    EditableRangeStart innerEditableRangeStart = builder.startEditableRange(); // 可编辑区域开始
    builder.moveToBookmark(bookmark.getName(), false, false);
    builder.endEditableRange(innerEditableRangeStart); // 可编辑区域结束
    builder.write(" "); // 插入空格,防止用户编辑清除标签内容时将文档标签也删除
}

// 保存文档
doc.save("E:/test1.docx");

编辑完成上传文件时,删除标签前部和尾部的空格:

// 加载文档
Document doc = new Document("E:/test1.docx");

DocumentBuilder builder = new DocumentBuilder(doc); // 文档指针
// 获取所有标签
BookmarkCollection bookmarks = doc.getRange().getBookmarks();
// 循环所有标签
for (int i = 0; i < bookmarks.getCount(); i++) {
    Bookmark bookmark = bookmarks.get(i);
    builder.moveToBookmark(bookmark.getName(), true, true);
    Node bookmarkStartNode = builder.getCurrentNode();
    bookmarkStartNode.remove(); // 将标签内容前部的空格删除
    builder.moveToBookmark(bookmark.getName(), false, false);
    Node bookmarkNextNode = builder.getCurrentNode();
    Node bookmarkEndNode = bookmarkNextNode.getPreviousSibling();
    bookmarkEndNode.remove(); // 将标签内容尾部的空格删除
}

// 保存文档
doc.save("E:/test2.docx");

2. 设置文档的数字签名

首先可安装 openssl:https://blog.csdn.net/HD243608836/article/details/137925745
生成证书文件 cert.pfx:https://www.volcengine.com/theme/1118836-O-7-1

设置文档数字签名:

Document inDoc = new Document("E:/test.docx");
Document outDoc = new Document("E:/test1.docx");

// 加载证书
CertificateHolder certificateHolder = CertificateHolder.create("E:/cert.pfx", "123456", null);
// 签署证书
DigitalSignatureUtil.sign(inDoc, outDoc, certificateHolder, "comments123456", new Date());

校验文档签名:

// 加载文档
Document signedDoc = new Document("E:/test2.docx");

// 检查文档是否经过数字签名
if (signedDoc.getDigitalSignatures().getCount() > 0) {
    // 验证数字签名
    DigitalSignature digitalSignature = signedDoc.getDigitalSignatures().get(0);
    String comments = digitalSignature.getComments();
    System.out.println(comments);
    boolean isValid = signedDoc.getDigitalSignatures().get(0).isValid();
    if (isValid) {
        System.out.println("Digital signature is valid.");
    } else {
        System.out.println("Digital signature is not valid.");
    }
} else {
    System.out.println("Document is not digitally signed.");
}

// 保存文档
signedDoc.save("E:/test2.docx");

3. 自定义文档 ID

设置文档 ID:

// 加载文档
Document doc = new Document("E:/test.docx");
// 添加文档属性
doc.getCustomDocumentProperties().add("custom_id", "custom_12345678");
// 保存文档
doc.save("E:/test1.docx");

校验文档 ID:

// 加载文档
Document doc = new Document("E:/test.docx");
// 获取文档属性
DocumentProperty custom_id = doc.getCustomDocumentProperties().get("custom_id");
System.out.println("custom_id: " + custom_id);
### 使用 Aspose.Words 进行文档模板操作 #### 官方文档资源 为了更好地理解和应用 Aspose.Words功能,建议访问其官方网站获取详细的 API 参考手册和技术支持。官方提供了详尽的指南和教程帮助开发者熟悉该库的各项特性[^1]。 #### 常见模板标签解析 Aspose.Words 支持多种用于构建复杂文档结构的模板标记语言。以下是几个常用的模板标签及其作用: - **条件语句 (If)** 条件逻辑允许根据特定变量的状态决定是否渲染某些部分的内容。例如,在合同文件中可以根据客户类型显示不同的条款。 - **循环体 (Foreach/For)** 当需要重复生成相似格式的数据项列表时非常有用,比如发票明细表中的商品条目。 - **宏定义与调用** 用户可以创建自定义函数简化复杂的排版需求;这些宏可以在整个文档内任意位置被引用执行。 通过学习上述基本概念以及更多高级特性,能够极大提升工作效率并减少手动编辑错误的发生概率[^2]。 #### 实际应用场景举例 下面给出一段简单的 C# 示例代码展示怎样加载预设好的 .dotx 文件作为基础框架,并填充实际业务所需的信息字段完成个性化定制化报告输出过程: ```csharp using System; using Aspose.Words; class Program { static void Main(string[] args){ // 加载现有模板文件 Document doc = new Document(@"C:\path\to\template.dotx"); // 替换单个书签内容 Bookmark bookmark = doc.Range.Bookmarks["CustomerName"]; if(bookmark != null){ bookmark.Text="John Doe"; } // 处理表格内的多行记录插入 Table table=doc.FirstSection.Body.Tables[0]; Row newRow=new Row(doc); Cell cell1=new Cell(doc);cell1.AppendParagraph("Item Name"); Cell cell2=new Cell(doc);cell2.AppendParagraph("$99.99"); newRow.Cells.Add(cell1); newRow.Cells.Add(cell2); table.Rows.Insert(1,newRow); // 将修改后的文档保存至指定路径下 doc.Save(@"C:\output\generated_report.docx", SaveFormat.DocX); } } ``` 此段脚本实现了基于给定模版批量生产含有不同参数值的新实例的功能,适用于诸如月度销售报表、员工绩效评估等多种场合下的自动化办公任务处理流程优化工作[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Whitemeen太白

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值