首页IT科技java将文件夹压缩成zip包(如何通过Java应用程序压缩PDF文档)

java将文件夹压缩成zip包(如何通过Java应用程序压缩PDF文档)

时间2025-06-20 23:34:17分类IT科技浏览7707
导读:PDF文档是我们日常办公中使用最频繁的文档格式。但因为大多数PDF文档都包含很多页面图像或大量图片,这就导致PDF文档过大,处理起来较为麻烦。PDF文件过大,就会导致传输或者下载的速度变慢,也会增加传输失败的风险,影响办公效率。因此我们需要对PDF文档进行压缩。本文将从以下两方面介绍如何通过Java应用程序压缩PDF文档。...

PDF文档是我们日常办公中使用最频繁的文档格式                。但因为大多数PDF文档都包含很多页面图像或大量图片                 ,这就导致PDF文档过大                         ,处理起来较为麻烦                          。PDF文件过大         ,就会导致传输或者下载的速度变慢        ,也会增加传输失败的风险                         ,影响办公效率         。因此我们需要对PDF文档进行压缩                。本文将从以下两方面介绍如何通过Java应用程序压缩PDF文档                         。

在使用PDF文件过程中                 ,经常会出现由于体积过大导致文件传输失败的情况         。遇到这种情况        ,我们可以先将PDF文件压缩一下再进行传输        。而除了压缩文档内容以外                         ,压缩图片是缩小PDF文档的主要方法之一                         。本文将分为2部分分别介绍如何通过Java代码压缩PDF文档                 。希望这篇文章能对大家有所帮助        。

压缩PDF文档中的内容及图片

压缩PDF文档中的高分辨率图片

1.引入jar

导入方法1:

手动引入                         。将Free Spire.PDF for Java下载到本地                 ,解压,找到lib文件夹下的Spire.PDF.jar文件                 。在IDEA中打开如下界面                         ,将本地路径中的jar文件引入Java程序:

导入方法2:如果您想通过 Maven安装                         ,则可以在 pom.xml 文件中添加以下代码导入 JAR 文件。

压缩PDF文档中的内容及图片

压缩PDF文档中的内容及图片的详细步骤如下:

创建 PdfDocument 类的对象                         。

使用 PdfDocument.loadFromFile() 方法加载 PDF 文档                          。

使用 PdfDocument.getFileInfo().setIncrementalUpdate() 方法将增量更新设置为false。

使用 PdfDocument.setCompressionLevel() 方法将压缩级别设置为最佳,以压缩文档中的内容                。 您可以从 PdfCompressionLevel 枚举中选择其他一些级别                          。

循环遍历文档中的页面                 ,使用 PdfPageBase.getImagesInfo() 方法获取每个页面的图像信息集合         。

遍历集合中的所有项目                         ,并使用 PdfBitmap.setQuality() 方法压缩特定图像的质量                。

使用 PdfPageBase.replaceImage() 方法将原始图像替换为压缩图像                         。使用 PdfDocument.saveToFile() 方法将文档保存到另一个 PDF 文件         。

完整代码

Java

import com.spire.pdf.PdfCompressionLevel; import com.spire.pdf.PdfDocument; import com.spire.pdf.PdfPageBase; import com.spire.pdf.exporting.PdfImageInfo; import com.spire.pdf.graphics.PdfBitmap; public class CompressPDFImage { public static void main(String[] args) { //创建 PdfDocument 类的对象        。 PdfDocument doc = new PdfDocument(); //加载 PDF 文档 doc.loadFromFile("测试文档.pdf"); //将增量更新设置为false doc.getFileInfo().setIncrementalUpdate(false); //将压缩级别设置为最佳 doc.setCompressionLevel(PdfCompressionLevel.Best); //循环遍历文档中的页面 for (int i = 0; i < doc.getPages().getCount(); i++) { //获取特定页面 PdfPageBase page = doc.getPages().get(i); //获取每个页面的图像信息集合 PdfImageInfo[] images = page.getImagesInfo(); //遍历集合中的项目 if (images != null && images.length > 0) for (int j = 0; j < images.length; j++) { //获取指定图像 PdfImageInfo image = images[j]; PdfBitmap bp = new PdfBitmap(image.getImage()); //设置压缩质量 bp.setQuality(20); //用压缩后的图片替换原始图片 page.replaceImage(j, bp); } //保存文件 doc.saveToFile("压缩PDF文档.pdf"); doc.close(); } } }

效果对比图

压缩 PDF 文档中的高分辨率图像

本方法仅对文档中的高分辨率图像进行无损压缩         ,而低分辨率的图像将不再被压缩                         。

创建 PdfDocument 类的对象                 。 使用 PdfDocument.loadFromFile() 方法加载 PDF 文档        。 使用 PdfDocument.getFileInfo().setIncrementalUpdate() 方法将 IncrementalUpdate 设置为 false                         。 声明一个 PdfPageBase 变量                 。 循环遍历页面并使用 PdfDocument.getPages().get() 方法获取特定页面。 循环遍历页面中的图像                         。并使用 page.tryCompressImage(info.Index) 方法压缩高分辨率图像                          。 使用 PdfDocument.saveToFile() 方法将文档保存到另一个 PDF 文件。

完整代码

Java

import com.spire.pdf.PdfDocument; import com.spire.pdf.PdfPageBase; import com.spire.pdf.exporting.PdfImageInfo; public class CompressPDFImage { public static void main(String[] args) { //创建 PdfDocument 类的对象 PdfDocument doc = new PdfDocument //加载 PDF 文档 doc.loadFromFile("示例文档.pdf"); //将IncrementalUpdate设置为false doc.getFileInfo().setIncrementalUpdate(false); //声明一个 PdfPageBase 变量 PdfPageBase page; //循环遍历页面 for (int i = 0; i < doc.getPages().getCount(); i++) { //获取指定页面 page = doc.getPages().get(i); if (page != null) { if(page.getImagesInfo() != null){ //循环遍历页面中的图像 for (PdfImageInfo info: page.getImagesInfo()) { //使用tryCompressImage方法压缩高分辨率图像 page.tryCompressImage(info.getIndex()); } } } } //保存文件 doc.saveToFile("输出结果.pdf"); } }

效果对比图

—本文完—

声明:本站所有文章                 ,如无特殊说明或标注                         ,均为本站原创发布                。任何个人或组织         ,在未征得本站同意时        ,禁止复制                、盗用                          、采集         、发布本站内容到任何网站                、书籍等各类媒体平台                          。如若本站内容侵犯了原著者的合法权益                         ,可联系我们进行处理         。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
uuid查询方法(udevadm info命令 – 查询udev数据库中的设备信息)