java将doc文件转pdf

将doc文件转为pdf

itextpdf+poi 方案,针对doc文件,非docx

缺点,不支持负责的格式,不支持图标,图片等。

需要的依赖

xml 复制代码
  <!-- https://mvnrepository.com/artifact/com.itextpdf/itextpdf -->
        <dependency>
            <groupId>com.itextpdf</groupId>
            <artifactId>itextpdf</artifactId>
            <version>5.5.13.3</version>
        </dependency>
       <!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml -->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>4.1.2</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml-schemas -->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml-schemas</artifactId>
            <version>4.1.2</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>ooxml-schemas</artifactId>
            <version>1.1</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.poi/poi-scratchpad -->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-scratchpad</artifactId>
            <version>4.1.2</version>
        </dependency>

java代码

java 复制代码
import com.google.common.io.Files;
import com.itextpdf.text.Document;
import com.itextpdf.text.DocumentException;
import com.itextpdf.text.Font;
import com.itextpdf.text.Paragraph;
import com.itextpdf.text.pdf.BaseFont;
import com.itextpdf.text.pdf.PdfWriter;
import lombok.extern.slf4j.Slf4j;
import org.apache.poi.hwpf.HWPFDocument;
import org.apache.poi.hwpf.extractor.WordExtractor;

import java.io.*;

/**
 * @Description 将doc文件转换为pdf
 */
@Slf4j
public class DocToPdfUtil {

    public static void toPdf(File orgFile, String outputFile) throws IOException {
        File file = new File(outputFile);
        try {
            ByteArrayOutputStream outputStream = toPdf(orgFile);
            Files.write(outputStream.toByteArray(), new File(outputFile));
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static ByteArrayOutputStream toPdf(File file) throws IOException, DocumentException {
        Document pdfDoc = null;
        WordExtractor extractor = null;
        try {
            // 读取DOC文件
            HWPFDocument doc = new HWPFDocument(new FileInputStream(file));
            extractor = new WordExtractor(doc);

            ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
            // 创建PDF文档
            pdfDoc = new Document();
            PdfWriter.getInstance(pdfDoc, outputStream);
            pdfDoc.open();

            // 写入内容
            String[] paragraphs = extractor.getParagraphText();
            // 加载中文字体
            BaseFont baseFont = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.EMBEDDED);
            Font font = new Font(baseFont, 12);

            for (String text : paragraphs) {
                Paragraph p = new Paragraph(text, font);
                pdfDoc.add(p);
            }
            log.info("==========doc转换pdf成功===============" + file.getAbsolutePath());
            return outputStream;
        } catch (Exception e) {
            log.info("==========doc转换pdf失败===============" + file.getAbsolutePath());
            e.printStackTrace();
            throw e;
        } finally {
            // 关闭资源
            if (null != pdfDoc) {
                pdfDoc.close();
            }
            if (null != extractor) {
                extractor.close();
            }
        }
    }
}

测试用例

java 复制代码
 DocToPdfUtil.toPdf(new File("C:\\mydoc\\明朝那点事.doc"), "C:\\mydoc\\明朝那点事" + System.currentTimeMillis() + ".pdf");

遇到的问题

转换的文件不显示中文

原因:字体问题,请设置字体。

java 复制代码
// 加载中文字体
            BaseFont baseFont = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.EMBEDDED);
            Font font = new Font(baseFont, 12);
相关推荐
Boilermaker19921 小时前
[Java 并发编程] Synchronized 锁升级
java·开发语言
Cherry的跨界思维1 小时前
28、AI测试环境搭建与全栈工具实战:从本地到云平台的完整指南
java·人工智能·vue3·ai测试·ai全栈·测试全栈·ai测试全栈
alonewolf_992 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
一嘴一个橘子2 小时前
spring-aop 的 基础使用(啥是增强类、切点、切面)- 2
java
sheji34162 小时前
【开题答辩全过程】以 中医药文化科普系统为例,包含答辩的问题和答案
java
恋爱绝缘体12 小时前
2020重学C++重构你的C++知识体系
java·开发语言·c++·算法·junit
wszy18093 小时前
新文章标签:让用户一眼发现最新内容
java·python·harmonyos
wszy18093 小时前
顶部标题栏的设计与实现:让用户知道自己在哪
java·python·react native·harmonyos
程序员小假4 小时前
我们来说一下无锁队列 Disruptor 的原理
java·后端
资生算法程序员_畅想家_剑魔4 小时前
Kotlin常见技术分享-02-相对于Java 的核心优势-协程
java·开发语言·kotlin