Java 使用PDFBox提取PDF文件中的图片

今天做PDF文件解析,遇到一个需求:提取文件中的图片并保存。使用的是流行的apache开源jar包pdfbox, 但还是遇到坑了,比如pdfbox版本太高或太低都不能用!!这个包竟然没有很好地做好兼容问题,有些方法在高版本说舍弃就舍弃了。暂时没有时间去研究版本间的区别。以下给我这个问题的解决方案。

pdfbox版本:1.8.13

maven传送门:

<!-- 处理pdf文件 -->  
<!-- https://mvnrepository.com/artifact/org.apache.pdfbox/pdfbox -->  
<dependency>  
    <groupId>org.apache.pdfbox</groupId>  
    <artifactId>pdfbox</artifactId>  
    <version>1.8.13</version>  
</dependency>  

 

代码:

package com.tbd.util;

import java.io.File;
import java.io.IOException;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.pdmodel.PDPage;
import org.apache.pdfbox.pdmodel.PDResources;
import org.apache.pdfbox.pdmodel.graphics.xobject.PDXObjectImage;

/**
 * 提取PDF中的图片
 * pdfbox 版本 1.8.13
 * @author Charlie Wu
 * 2018/05/24
 */
public class PDF2Image {
	/**
	 * 提取
	 * @param file			PDF文件
	 * @param targetFolder 	图片存放目录
	 * @return 
	 */
	public static boolean extractImages(File file, String targetFolder) {  
		boolean result = true;
		
		try{
			PDDocument document = PDDocument.load(file);  
			 
		 	List<PDPage> pages = document.getDocumentCatalog().getAllPages();
			Iterator<PDPage> iter = pages.iterator();
			int count = 0;
			while( iter.hasNext()){
			    PDPage page = (PDPage)iter.next();
			    PDResources resources = page.getResources();
			    Map<String, PDXObjectImage> images = resources.getImages();
			    if(images != null)
			    {
			        Iterator<String> imageIter = images.keySet().iterator();
			        while(imageIter.hasNext())
			        {
			        	count++;
			            String key = (String)imageIter.next();
			            PDXObjectImage image = (PDXObjectImage)images.get( key );
			            String name = file.getName() + "_" + count;	// 图片文件名
						image.write2file(targetFolder + name);		// 保存图片
			        }
			    }
			}
		} catch(IOException ex){
			ex.printStackTrace();
			return false;
		}
		
		return result;
    } 
	
	
	
	public static void main(String[] args) {
		File file = new File("F:/test.pdf");
		String targerFolder = "F:/target/";
		
		extractImages(file, targerFolder);
	}
}

  

转载于:https://www.cnblogs.com/amCharlie/p/9083675.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用 Apache PDFBox 库来提取 PDF 文件的内容。下面是一个简单的例子,演示如何使用 PDFBox 提取 PDF 文件的文本内容: ```java import java.io.File; import java.io.IOException; import org.apache.pdfbox.pdmodel.PDDocument; import org.apache.pdfbox.text.PDFTextStripper; public class PdfBoxTest { public static void main(String[] args) throws IOException { // 加载 PDF 文件 PDDocument document = PDDocument.load(new File("test.pdf")); // 创建一个 PDFTextStripper 对象 PDFTextStripper stripper = new PDFTextStripper(); // 获取 PDF 文件的文本内容 String text = stripper.getText(document); // 输出文本内容 System.out.println(text); // 关闭 PDF 文件 document.close(); } } ``` 运行该程序,可以得到 PDF 文件的文本内容。 当然,如果需要提取 PDF 文件的其它内容,比如图片、表格等,也可以使用 PDFBox 提供的相应工具类来实现。例如,使用 PDFBox 提取 PDF 文件图片,可以使用如下代码: ```java import java.io.File; import java.io.IOException; import java.util.List; import org.apache.pdfbox.pdmodel.PDDocument; import org.apache.pdfbox.pdmodel.PDPage; import org.apache.pdfbox.rendering.PDFRenderer; public class PdfBoxTest { public static void main(String[] args) throws IOException { // 加载 PDF 文件 PDDocument document = PDDocument.load(new File("test.pdf")); // 创建 PDFRenderer 对象 PDFRenderer renderer = new PDFRenderer(document); // 获取 PDF 文件的所有页面 List<PDPage> pages = document.getPages(); // 遍历所有页面,提取图片 for (int i = 0; i < pages.size(); i++) { PDPage page = pages.get(i); int pageNum = i + 1; String fileName = "page" + pageNum + ".png"; renderer.renderImageWithDPI(pageNum - 1, 300, fileName); } // 关闭 PDF 文件 document.close(); } } ``` 运行该程序,可以将 PDF 文件的所有页面转换成 PNG 图片保存到本地。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值