Java PDFBox 提取页数、PDF转图片

PDF 提取

使用Apache 的pdfbox组件对PDF文件解析读取和转图片。

Maven 依赖

导入下面的maven依赖:

<dependency>
	<groupId>org.apache.pdfbox</groupId>
	<artifactId>pdfbox</artifactId>
    <version>2.0.30</version>
</dependency>

读取总页数 和 转图片

dpi越大转换后越清晰,相对转换速度越慢,建议取值500-800。

图片类型可以选择jpg或者png:

  1. jpg图片大小比png要小很多
  2. jpg图片转换速度比png快
  3. 相同dpi jpg和png清晰度差别不大
package tech.pplus.common.util;

import lombok.extern.slf4j.Slf4j;
import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.rendering.PDFRenderer;
import org.springframework.web.util.UriComponentsBuilder;

import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.net.URL;
import java.util.LinkedList;
import java.util.List;

/**
 * @author zl
 * @date 2024-01-24
 */
@Slf4j
public class PDFUtil {
    /**
     * dpi越大转换后越清晰,相对转换速度越慢
     */
    private static final Integer DPI = 500;
    private static final String IMG_SUFFIX = "jpg";

    /**
     * pdf 一页切分 一张图片
     *
     * @param url pdf文件url
     * @param dstDir 图片输出目录
     * @return
     */
    public static List<File> splitPage(String url, String dstDir) {
        dstDir = dstDir.endsWith(File.separator) ? dstDir : dstDir + File.separator;
        List<File> files = new LinkedList<>();
        try (InputStream is = new URL(url).openConnection().getInputStream();
             PDDocument document = PDDocument.load(is)) {
             //获取总页数
            int numberOfPages = document.getNumberOfPages();

            PDFRenderer renderer = new PDFRenderer(document);
            //提取url文件名称
            String path = UriComponentsBuilder.fromHttpUrl(url).build().getPath();
            String fileName = path.substring(path.lastIndexOf("/") + 1);
            for (int i = 0; i < numberOfPages; i++) {
                File dstFile = new File(dstDir + fileName + String.format(".page%d.%d.%s", i + 1, DPI, IMG_SUFFIX));
                //把页面转图片
                BufferedImage image = renderer.renderImageWithDPI(i, DPI);
                ImageIO.write(image, IMG_SUFFIX, dstFile);
                files.add(dstFile);
            }

        } catch (IOException e) {
            log.error("PDF分割异常,url={},destDir={},error={}", url, dstDir,e.getMessage(), e);
        }
        return files;
    }
}

测试参数:

  1. pdfUrl:https://s3.us-west-1.amazonaws.com/tax.withtutti.com/test/upload/202401/83610d194d2d48498afa9451e39b198d.pdf
  2. dstDir: /tmp

输出结果:

在这里插入图片描述
在这里插入图片描述

  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
使用JavaPDFBox库可以轻松地提取指定区域的图片。下面是一个基本的步骤: 1. 首先,需要导入PDFBox库。可以从官方网站(https://pdfbox.apache.org/)下载并将其添加到Java项目中。 2. 创建一个PDF文档的PDDocument对象,并使用该文档的路径初始化它。例如: ```java PDDocument document = PDDocument.load(new File("path/to/pdf")); ``` 3. 获取第一页的PDPage对象。由于PDFBox库使用从零开始的索引,第一页的索引为0。例如: ```java PDPage page = document.getPage(0); ``` 4. 创建一个PDFRenderer对象,将PDPage对象传递给它。该对象可以渲染PDF页面为图像。例如: ```java PDFRenderer renderer = new PDFRenderer(document); ``` 5. 确定要提取图片的区域。可以使用PDRectangle对象来表示区域的坐标和大小。例如,提取左上角为(100, 100),宽度和高度都为200的区域: ```java PDRectangle region = new PDRectangle(100, 100, 200, 200); ``` 6. 使用PDFRenderer的renderImageWithDPI方法将区域渲染为图像。这个方法需要提供图像的DPI(每英寸点数)。例如,将DPI设置为96: ```java BufferedImage image = renderer.renderImageWithDPI(0, 96); ``` 7. 从图像中截取指定区域。使用getSubimage方法,传递区域的左上角坐标和大小。例如: ```java BufferedImage extractedImage = image.getSubimage((int) region.getLowerLeftX(), (int) region.getLowerLeftY(), (int) region.getWidth(), (int) region.getHeight()); ``` 8. 现在,可以对提取的图像进行任何所需的处理,例如保存到磁盘或显示在图形用户界面中。例如,保存图像到指定路径: ```java ImageIO.write(extractedImage, "png", new File("path/to/extracted/image.png")); ``` 9. 最后,不要忘记关闭PDDocument对象以释放资源: ```java document.close(); ``` 这是使用Java PDFBox提取指定区域图像的基本过程。根据实际需求,还可以进一步处理图像或适应更复杂的用例。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

冲上云霄的Jayden

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值