Java实现PDF转为Word文档的示例代码

作者:E-iceblue 时间:2021-10-05 02:19:26 

众所周知,PDF文档除了具有较强稳定性和兼容性外, 还具有较强的安全性,在工作中可以有效避免别人无意中对文档内容进行修改。但与此同时,也妨碍了对文档的正常的修改。这时我们可以将PDF转为Word文档进行修改或再编辑。使用软件将 PDF 文档转换为 Word 文档十分简单,然而要在转换时保持布局甚至字体格式却并不容易。本文将分为以下两部分介绍如何在保持布局的情况下将PDF转为Word文档。

  • 将 PDF 转换为固定布局的 Doc/Docx 文档

  • 将 PDF 转换为流动形态的 Doc/Docx 文档

固定布局模式转换速度快,有利于最大程度保持 PDF 文件的原貌。但是,生成的文档的可编辑性将受到限制,因为 PDF 中的每一行文本将在生成的 Word 文档中显示在单独的框架中。

流动形态是一种完整的识别模式。转换后的内容不会以框架形式呈现,并且生成的文档的结构是可流动的。生成的 Word 文档很容易重新编辑,但看起来可能与原始 PDF 文件不同。

代码编译环境

IntelliJ IDEA 2018(jdk 1.8.0)

PDF Jar包:Free Spire.PDF for Java 5.1.0

1.引入jar

导入方法1:

手动引入。将Free Spire.PDF for Java下载到本地,解压,找到lib文件夹下的Spire.PDF.jar文件。在IDEA中打开如下界面,将本地路径中的jar文件引入Java程序:

Java实现PDF转为Word文档的示例代码

导入方法2:如果您想通过 Maven安装,则可以在 pom.xml 文件中添加以下代码导入 JAR 文件

<repositories>
       <repository>
           <id>com.e-iceblue</id>
           <url>https://repo.e-iceblue.cn/repository/maven-public/</url>
       </repository>
   </repositories>
<dependencies>
   <dependency>
       <groupId>e-iceblue</groupId>
       <artifactId>spire.pdf.free</artifactId>
       <version>5.1.0</version>
   </dependency>
</dependencies>

将 PDF 转换为固定布局的 Doc/Docx 文档

  • 以下是将 PDF 转为固定布局的Doc/Docx 文档的具体步骤。

  • 创建一个 PdfDocument 对象。

  • 使用 PdfDocument.loadFromFile() 方法加载 PDF 文件。

  • 使用 PdfDocument.saveToFile(String fileName, FileFormat fileFormat) 方法将 PDF 文档转换为 Doc 或 Docx 格式文件。

完整代码

import com.spire.pdf.FileFormat;
import com.spire.pdf.PdfDocument;

public class ConvertPdfToWordWithFixedLayout {

public static void main(String[] args) {

//创建一个 PdfDocument 对象
       PdfDocument doc = new PdfDocument();

//加载 PDF 文件
       doc.loadFromFile("C:\\Users\\Administrator\\Desktop\\sample.pdf");

//将PDF转换为Doc格式文件并保存
       doc.saveToFile("output/ToDoc.doc", FileFormat.DOC);

//将PDF转换为Docx格式文件并保存
       doc.saveToFile("output/ToDocx.docx", FileFormat.DOCX);
       doc.close();
   }
}

将 PDF 转换为流动形态的 Doc/Docx 文档

以下是将 PDF 转换为流动形态的 Doc/Docx 文档的具体步骤:

  • 创建一个 PdfDocument 对象。

  • 使用 PdfDocument.loadFromFile() 方法加载 PDF 文件。

  • 使用 PdfDocument. getConvertOptions().setConvertToWordUsingFlow() 方法将转换模式设置为流。

  • 使用 PdfDocument.saveToFile(String fileName, FileFormat fileFormat) 方法将 PDF 文档转换为 Doc 或 Docx 格式文件。

完整代码

import com.spire.pdf.FileFormat;
import com.spire.pdf.PdfDocument;

public class ConvertPdfToWordWithFlowableStructure {

public static void main(String[] args) {

//创建一个 PdfDocument 对象
       PdfDocument doc = new PdfDocument();

//加载 PDF 文件
       doc.loadFromFile("C:\\Users\\Administrator\\Desktop\\sample.pdf");

//将 PDF 转换为流动形态的Word
       doc.getConvertOptions().setConvertToWordUsingFlow(true);

//将PDF转换为Doc格式文件并保存
       doc.saveToFile("output/ToDoc.doc", FileFormat.DOC);

//将PDF转换为Docx格式文件并保存
       doc.saveToFile("output/ToDocx.docx", FileFormat.DOCX);
       doc.close();
   }
}

效果图

Java实现PDF转为Word文档的示例代码

来源:https://www.cnblogs.com/Yesi/p/17061190.html

标签:Java,PDF,Word
0
投稿

猜你喜欢

  • AndroidStudio实现微信界面设计

    2022-09-16 22:45:40
  • Java 阻塞队列和线程池原理分析

    2022-04-19 11:57:45
  • C#二维数组与多维数组的具体使用

    2023-07-30 23:53:49
  • java中public class与class的区别详解

    2023-04-09 11:49:40
  • SpringBoot接入支付宝支付的方法步骤

    2022-02-16 05:34:16
  • springboot publish event 事件机制demo分享

    2022-11-19 23:45:45
  • springboot跨域CORS处理代码解析

    2022-07-29 21:12:20
  • Java实现pdf转图片案例

    2022-08-11 21:45:41
  • C#实现一阶卡尔曼滤波算法的示例代码

    2022-12-23 05:28:45
  • C#实现简单的汽车租赁系统

    2022-08-17 00:51:52
  • Springboot整个Quartz实现动态定时任务的示例代码

    2023-04-12 20:30:02
  • 在Android app中实现九(n)宫格图片连续滑动效果

    2022-10-14 21:09:23
  • java实现将域名解析成ip示例

    2021-11-20 10:33:33
  • Android Studio连接手机设备教程

    2021-06-10 14:40:23
  • c#.net 常用函数和方法集

    2022-08-03 01:44:00
  • c# 实现KMP算法的示例代码

    2023-12-02 06:35:19
  • C# wpf简单颜色板的实现

    2022-02-11 20:08:38
  • SpringBoot2使用JTA组件实现基于JdbcTemplate多数据源事务管理(亲测好用)

    2021-10-12 06:36:09
  • 如何使用Spring工具类动态匹配url

    2021-06-16 05:09:08
  • Android项目实战之ListView悬浮头部展现效果实现

    2022-08-11 16:35:32
  • asp之家 软件编程 m.aspxhome.com