当前位置: 首页 > news >正文

Spire.doc 合并word,复制word

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

1. 引入依赖

    <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>

2. 如果只是合并文档,可以使用spire.doc 自带的合并方法

    public static void main(String[] args) {Document doc = new Document("test.docx");doc.insertTextFromFile("append.docx", FileFormat.Docx);doc.saveToFile("out.docx", FileFormat.Docx);}

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

3. 使用复制元素的方法来追加文档内容

    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());}}}

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

http://www.lryc.cn/news/500190.html

相关文章:

  • 【Spring项目】表白墙,留言板项目的实现
  • 分布式事务-nacos/seata在windows环境下部署及开发
  • 分布式微服务架构下的密码安全性方案
  • 基于pytorch的深度学习基础4——损失函数和优化器
  • 网络安全信息收集(总结)更新
  • web斗地主游戏实现指北
  • SpringMVC其他扩展
  • 【Linux】网络服务
  • 工作:SolidWorks从3D文件导出2D的DWG或DXF类型文件方法
  • IDL学习笔记(五)MODIS数据(Grid)
  • JavaScript语言介绍
  • Lua使用点号和冒号的区别
  • LLM - 开源视觉多模态 LLaVA-CoT(o1) 深度推理模型 测试与源码 教程
  • Ansible的yum和saltstack的哪个功能相似
  • paimon0.9记录
  • Java 中 List 接口的学习笔记
  • 【原生js案例】webApp实现鼠标移入移出相册放大缩小动画
  • LVGL9 定时器模块
  • Qt学习笔记第51到60讲
  • 网页设计--axios作业
  • SpringBoot 整合 Avro 与 Kafka 详解
  • 若依 ruoyi VUE el-select 直接获取 选择option 的 label和value
  • 大数据-155 Apache Druid 架构与原理详解 数据存储 索引服务 压缩机制
  • 修改MySQL存储路径
  • Git常用的命令【提交与回退】
  • 详解:HTTP/HTTPS协议
  • 0.96寸OLED---STM32
  • 保姆级教学 uniapp绘制二维码海报并保存至相册,真机正常展示图片二维码
  • 常用Vim操作
  • 【C#】NET 9中LINQ的新特性-CountBy