Spire.doc 合并word,复制word

之前使用的poi来实现这个功能,然后发现在复制chart时,边框样式无法修改,于是就使用了spire.doc

  1. 引入依赖
XML 复制代码
    <repositories>
        <repository>
            <id>com.e-iceblue</id>
            <name>e-iceblue</name>
            <url>https://repo.e-iceblue.cn/repository/maven-public/</url>
        </repository>
    </repositories>
    <dependencies>

        <dependency>
            <groupId>e-iceblue</groupId>
            <artifactId>spire.doc.free</artifactId>
            <version>5.2.0</version>
        </dependency>
        
    </dependencies>
  1. 如果只是合并文档,可以使用spire.doc 自带的合并方法
java 复制代码
    public static void main(String[] args) {
        Document doc = new Document("test.docx");
        doc.insertTextFromFile("append.docx", FileFormat.Docx);
        doc.saveToFile("out.docx", FileFormat.Docx);
    }

这个方法有个弊端,就是两个文档中间会自动分节,如果对格式有要求的话,建议用下面的方法

  1. 使用复制元素的方法来追加文档内容
java 复制代码
    public static void appendDoc(Document srcDoc, Document appendDoc) {
        SectionCollection sections = appendDoc.getSections();
        for (Section section : (Iterable<Section>) sections) {
            for (int j = 0; j < section.getBody().getChildObjects().getCount(); j++) {
                //获取文档中的段落和表格
                DocumentObject obj = section.getBody().getChildObjects().get(j);
                //将文档中的段落和表格插入到新的文档中
                srcDoc.getLastSection().getBody().getChildObjects().add(obj.deepClone());
            }
        }
    }

核心思想是从目标文档的最后一节开始追加源文档的每个元素,这个方法对文档格式没有任何影响,只是单纯的追加内容,如果中间需要加空行或者其他要素,需要修改上面的方法

相关推荐
Javatutouhouduan2 分钟前
大厂Java岗最新面试真题汇总!
java·java面试·后端开发·java编程·java程序员·互联网大厂·java八股文
逻辑驱动的ken3 分钟前
Java高频面试考点场景题23
java·开发语言·数据库·面试·职场和发展·哈希算法
xxjj998a10 分钟前
PHP vs Java:核心区别与应用场景全解析
java·开发语言·php
用户2986985301425 分钟前
Java 从零生成 Word 文档:段落、图片与表格操作
java·后端
2401_8332693027 分钟前
Java IO流:从字节到字符的桥梁
java·开发语言
月落归舟41 分钟前
深入剖析乐观锁背后的原理
java·乐观锁
SimonKing1 小时前
OpenCode 在 IDEA 中使用 ACP 协议 VS 直接使用 TUI,哪个编程方式更是你的菜?
java·后端·程序员
NE_STOP1 小时前
Redis--持久化之AOF
java
budingxiaomoli1 小时前
注册中心的其他实现-Nacos
java·spring cloud·微服务
大大大大晴天️1 小时前
Flink技术实践-Flink重启策略选型指南
java·大数据·flink