PDF转word

一、引入maven依赖
shell 复制代码
<dependency>
	<groupId>com.aspose</groupId>
	<artifactId>aspose-pdf</artifactId>
	<version>22.10</version>
</dependency>
二、核心代码
java 复制代码
import com.aspose.pdf.Document;
import com.aspose.pdf.PageInfo;
import com.aspose.pdf.SaveFormat;
import java.io.FileOutputStream;
import java.io.IOException;

/**
 * @author :jerry
 * @date :Created in 2022/11/15 19:00
 * @description:PDF转word
 * @version: V1.1
 */
public class PdfWord {

  //测试
    public static void main(String[] args) throws IOException {
        pdfDoc("/Users/jerry/Downloads/考研背景知识盘点(政英数).pdf", ".DOCX");

    }
  
    //pdf转doc
    public static String pdfDoc(String pdfPath, String fileFormatValue) {
        String wordPath = pdfPath.substring(0, pdfPath.lastIndexOf(".")) + fileFormatValue;
        try {
            //新建一个word文档
            FileOutputStream os = new FileOutputStream(wordPath);
            //doc是将要被转化的word文档
            Document doc = new Document(pdfPath);
            //全面支持DOC, DOCX, OOXML, RTF HTML, OpenDocument, PDF, EPUB, XPS, SWF 相互转换
            doc.setPageInfo(new PageInfo());
            doc.save(os, getTypes(fileFormatValue));
            os.close();
            //转化用时

        } catch (Exception e) {
            System.out.println("Pdf 转 Word 失败...");
            e.printStackTrace();
        }
        return wordPath;
    }

    public static SaveFormat getTypes(String fileFormatValue) {
        SaveFormat docX = SaveFormat.DocX;
        switch (fileFormatValue) {
            //docX
            case ".DOCX":
                //黄金
                docX = SaveFormat.DocX;
                break;
            case ".PDF":
                //Pdf
                docX = SaveFormat.Pdf;
                break;
            case ".Html":
                //Html
                docX = SaveFormat.Html;
                break;
            case ".Xml":
                //Xml
                docX = SaveFormat.Xml;
                break;
            case ".XPS":
                //XPS
                docX = SaveFormat.Xps;
                break;
            case ".Excel":
                //Excel
                docX = SaveFormat.Excel;
                break;
            case ".svg":
                //Excel
                docX = SaveFormat.Svg;
                break;
            default:
                //普通会员
                docX = SaveFormat.Doc;
        }
        return docX;
    }
}

注意事项:

​ 1.有时候报错,可能是因为本机缺少相应的字体包,直接去字体网站 (https://cn.ffonts.net/)下载字体,放入本机的系统字体目录即可.

相关推荐
玩泥巴的3 天前
.NET驾驭Word之力:理解Word对象模型核心 (Application, Document, Range)
word·二次开发·office·com互操作
阿幸软件杂货间4 天前
Office转PDF转换器v1.0.py
开发语言·pdf·c#
reembarkation4 天前
使用pdfjs-dist 预览pdf,并添加文本层的实现
前端·javascript·pdf
reembarkation4 天前
vue-pdf 实现blob数据的预览
javascript·vue.js·pdf
玩泥巴的4 天前
.NET驾驭Word之力:COM组件二次开发全攻略之连接Word与创建你的第一个自动化文档
word·二次开发·com互操作
Light604 天前
领码方案|Linux 下 PLT → PDF 转换服务超级完整版:异步、权限、进度(一气呵成)
linux·spring boot·pdf·gpcl6/ghostpcl·s3/oss·权限与审计·异步与进度
伟贤AI之路4 天前
【分享】中小学教材课本 PDF 资源获取指南
人工智能·pdf
东风西巷4 天前
PDFgear:免费全能的PDF处理工具
前端·pdf·软件需求
辣香牛肉面5 天前
[Windows] 搜索文本2.6.2(从word、wps、excel、pdf和txt文件中查找文本的工具)
word·excel·wps·搜索文本
Sunny_yiyi5 天前
Java根据模版导出PDF文件
java·开发语言·pdf