如何通过Java应用程序将 PDF转为Word文档
2023-03-31 10:39:13 时间
众所周知,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程序:
导入方法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 格式文件。
完整代码
Java
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 格式文件。
完整代码
Java
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 技术篇 - java同时连接多种数据库执行sql语句的兼容性验证,数据库类型包括:oracle、sqlserver、DB2、人大金仓、达梦、PG、瀚高、polardb
- Java 技术篇 - 前端浏览器发送一次url请求后端ServerSocket接收到两次请求原因及解决方法,GET /favicon.ico HTTP/1.1问题处理
- Java 技术篇 - ServerSocket接收http的url请求中包含中文的处理方法,URLDecode与URLEncode,url解码与编码
- Java 技术篇 - 通过exe4j打包后的程序运行过程中出现中文乱码问题解决
- Java 技术篇 - 从指定的web网页页面中读取html内容实例演示,从http协议下的url地址中读取web页面内容方法
- Java 技术篇 - 启动web服务接收浏览器请求并响应实例演示,解决socket响应浏览器显示中文乱码问题,web服务response响应设置浏览器显示字体方法
- Java 技术篇 - 连接oracle数据库执行sql使用close()关闭createStatement()无效无法清除游标缓存问题解决,报“ORA-01000: 超出打开游标的最大数“错误解决方法
- Java 技术篇-使用poi开源jar包实现读取excel实例演示,poi-3.17.jar获取
- Java 技术篇-linux系统下安装jdk、设置java环境变量实例演示
- Java 技术篇-利用ClipboardOwner实现实时监听剪切板功能实例演示
- Java 技术篇-借助自定义对象实现函数返回多个不同类型的值实例演示
- Java 技术篇-利用exe4j工具生成exe文件实例演示,IntelliJ IDEA将项目转化为jar包方法,运行生成后的程序弹出exe4j提示处理,生成的程序显示控制台设置方法
- Java 技术篇-IntelliJ IDEA修改类名后运行提示找不到或无法加载主类问题解决方法
- Java 技术篇-IntelliJ IDEA修改java、jdk版本实例演示
- Java 技术篇-使用IDEA开发java代码实例演示,IntelliJ IDEA的安装与使用
- Java 技术篇-java连接并操作数据库实例演示,执行查询、插入、更新和删除操作
- Java 技术篇-IntelliJ IDEA 导入数据库驱动jar包实例演示
- Java 自动化 - 调用sikuli实现图像识别桌面自动化:打开浏览器查询天气实例演示,java调用图形化脚本语言sikuli实现自动化
- 复杂并发场景下的并发调度模型在转转的演进之路