Java實現(xiàn)pdf文件合并的使用示例
更新時間:2023年12月15日 09:39:08 作者:lang20150928
本文主要介紹了Java實現(xiàn)pdf文件合并的使用示例,主要是將需要合并的pdf文件都拷貝到指定目錄a中,調(diào)用該工具類將該目錄作為第一個參數(shù),第二個參數(shù)傳入輸出文件對象即可,感興趣的可以了解一下
在maven項目中引入以下依賴包
<dependencies> <dependency> <groupId>org.apache.pdfbox</groupId> <artifactId>pdfbox-examples</artifactId> <version>3.0.1</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.9.0</version> </dependency> </dependencies>
創(chuàng)建一個工具類
package org.apache.pdfbox.utils; import org.apache.commons.io.FileUtils; import org.apache.pdfbox.examples.util.PDFMergerExample; import org.apache.pdfbox.io.RandomAccessRead; import org.apache.pdfbox.io.RandomAccessReadMemoryMappedFile; import java.io.File; import java.io.IOException; import java.io.InputStream; import java.util.ArrayList; import java.util.Arrays; import java.util.Comparator; import java.util.List; import java.util.function.Predicate; import java.util.stream.Collectors; /** * @author: guanglai.zhou * @date: 2023/12/14 13:15 */ public class PdfMergerUtils { /** * 合并指定目錄中的pdf文件 * * @param fromDir 指定目錄 * @param descFile 目標(biāo)pdf文件 * @return 目標(biāo)pdf文件 * @throws IOException */ public static File merge(String fromDir, String descFile) throws IOException { final File resultFile = new File(descFile); File file = new File(fromDir); List<File> files = new ArrayList<>(); list(file, new Predicate<File>() { @Override public boolean test(File file) { return true; } }, new Predicate<File>() { // 選擇pdf文件 @Override public boolean test(File file) { return file.getPath().endsWith(".pdf"); } }, files); if (files.isEmpty()) { throw new RuntimeException("源文件不存在pdf格式文檔?"); } // files.sort(Comparator.comparing(File::getName)); if (resultFile.exists()) { FileUtils.forceDelete(resultFile); } mergePdfs(resultFile, files); return resultFile; } /** * 針對文件進(jìn)行遍歷 如果文件夾滿足directoryPredicate,則繼續(xù)遍歷文件夾,如果是文件,則判斷是否滿足filePredicate,如果滿足則添加到 * collector結(jié)果集當(dāng)中 * * @param file 文件夾 * @param directoryPredicate 文件夾預(yù)期 為null 則不針對文件夾做過濾 * @param filePredicate 文件預(yù)期 為null 則不針對文件做過濾 * @param collector 收集器 收集所有符合條件的文件 */ public static void list(File file, Predicate<File> directoryPredicate, Predicate<File> filePredicate, List<File> collector) { File[] childFiles = file.listFiles(); if (childFiles == null) { return; } // 根據(jù)腳本名稱進(jìn)行排序 List<File> fileList = Arrays.stream(childFiles).sorted(Comparator.comparing(File::getName)).collect(Collectors.toList()); for (File childFile : fileList) { if (childFile.isDirectory()) { boolean pass = directoryPredicate == null || directoryPredicate.test(childFile); if (pass) { // 繼續(xù)遍歷子文件夾目錄 list(childFile, directoryPredicate, filePredicate, collector); } } else { boolean pass = filePredicate == null || filePredicate.test(childFile); if (pass) { collector.add(childFile); } } } } private static void mergePdfs(File resultFile, List<File> files) throws IOException { PDFMergerExample example = new PDFMergerExample(); List<RandomAccessRead> sources = new ArrayList<>(); for (File currFile : files) { sources.add(new RandomAccessReadMemoryMappedFile(currFile)); } InputStream inputStream = example.merge(sources); FileUtils.copyInputStreamToFile(inputStream, resultFile); } }
將需要合并的pdf文件都拷貝到指定目錄a中,調(diào)用該工具類將該目錄作為第一個參數(shù),第二個參數(shù)傳入輸出文件對象即可。
到此這篇關(guān)于Java實現(xiàn)pdf文件合并的使用示例的文章就介紹到這了,更多相關(guān)Java pdf文件合并內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
springboot controller參數(shù)注入方式
這篇文章主要介紹了springboot controller參數(shù)注入方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05淺談SpringBoot項目如何讓前端開發(fā)提高效率(小技巧)
這篇文章主要介紹了淺談SpringBoot項目如何讓前端開發(fā)提高效率(小技巧),主要介紹了Swagger和Nginx提高效率的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-04-04Java使用訪問者模式解決公司層級結(jié)構(gòu)圖問題詳解
這篇文章主要介紹了Java使用訪問者模式解決公司層級結(jié)構(gòu)圖問題,結(jié)合實例形式分析了訪問者模式的概念、原理及Java使用訪問者模式解決公司曾經(jīng)結(jié)構(gòu)圖問題的相關(guān)操作技巧與注意事項,需要的朋友可以參考下2018-04-04