Java實現(xiàn)Excel轉(zhuǎn)PDF的兩種方法詳解
使用具將Excel轉(zhuǎn)為PDF的方法有很多,在這里我給大家介紹兩種常用的方法,分別應(yīng)對兩種不一樣的使用場景,接下來我在springboot環(huán)境下給大家做一下演示!
一、使用spire轉(zhuǎn)化PDF
首先介紹一種比較簡單的方法,這種方法可以使用短短的幾行代碼就可以將我們的Excel文件中的某一個sheet頁或者整個Excel文件轉(zhuǎn)為PDF格式,
但是這種方法有一個缺點就是這個jar包是收費(fèi)的,只能導(dǎo)出3個sheet頁,不適合有多個sheet頁的Excel文件的轉(zhuǎn)換。
使用時首先在pom文件中導(dǎo)入workbook的所需依賴:
<dependency> <groupId>e-iceblue</groupId> <artifactId>spire.xls.free</artifactId> <version>2.2.0</version> </dependency>
1、使用spire將整個Excel文件轉(zhuǎn)為PDF
使用workbook導(dǎo)出整個Excel文件的代碼只需要兩步,我們可以直接看代碼示例:
/** * 使用spire簡單整個Excel轉(zhuǎn)換為pdf * * @param inputFilePath Excel文件路徑 * @param outputFilePath 導(dǎo)出的PDF文件路徑 */ public static void totalExcelToPDF(String inputFilePath, String outputFilePath) { Workbook wb = new Workbook(); // 引入Excel文件 wb.loadFromFile(inputFilePath); // 導(dǎo)出PDF文件 wb.saveToFile(outputFilePath, FileFormat.PDF); }
2、指定單個的sheet頁轉(zhuǎn)為PDF
使用spire可以將指定單個sheet頁面轉(zhuǎn)為PDF格式輸出,在這里需要輸入指定的sheet頁的下標(biāo)。代碼示例如下:
/** * 使用spire將單個sheet轉(zhuǎn)成pdf * * @param inputFilePath Excel文件路徑 * @param outputFilePath 導(dǎo)出的PDF文件路徑 * @param sheetNum 導(dǎo)出的sheet頁下標(biāo) */ public static void partExcelToPDF(String inputFilePath, String outputFilePath, int sheetNum) { //加載Excel文檔 Workbook wb = new Workbook(); wb.loadFromFile(inputFilePath); //獲取到哪一個sheet頁 Worksheet sheet = wb.getWorksheets().get(sheetNum); //調(diào)用方法保存為PDF格式 sheet.saveToPdf(outputFilePath); }
以上使用spire來實現(xiàn)Excel轉(zhuǎn)換PDF的方法雖然簡單,但是不適合于較大的Excel文件轉(zhuǎn)化,只適合有小于3個sheet頁的文件使用。
所以在企業(yè)項目開發(fā)中,如果想要將大批量的Excel文件或sheet頁較多的Excel文件整體轉(zhuǎn)化為PDF格式的話,還是推薦使用下面這種方法,而且這種方法使用穩(wěn)定還免費(fèi)!
二、使用jacob實現(xiàn)Excel轉(zhuǎn)PDF(推薦使用)
1、環(huán)境準(zhǔn)備
在使用jacob之前需要做一些準(zhǔn)備,首先需要去下載jacob的壓縮包jacob.zip ,下載地址
解壓之后,得到如下內(nèi)容:
如果你是64位系統(tǒng)就用 x64的dll,32位系統(tǒng)就用x86的dll。之后我們需要將dll文件放入放入你的jdk的bin目錄下,如下圖所示:
這樣前期準(zhǔn)備工作就做好了,
接下來在在Maven中引入Jacob所需依賴:
<!--jacob依賴--> <dependency> <groupId>com.jacob</groupId> <artifactId>jacob</artifactId> <version>1.19</version> <scope>system</scope> <!--本地的jacob.jar的路徑--> <systemPath>D:\DevInstall\jacob18,19\jacob-1.19\jacob.jar</systemPath> </dependency>
注意:上面依賴中標(biāo)簽的值就是你的jacob.jar的具體路徑,這個改成自己剛才下載的對應(yīng)的路徑就行了。
2、執(zhí)行導(dǎo)出PDF
執(zhí)行Excel導(dǎo)出PDF的方法如下:其中比較重要的地方進(jìn)行了注釋,方法可以直接拿來用即可!
? /** * 使用jacob實現(xiàn)excel轉(zhuǎn)PDF * * @param inputFilePath 導(dǎo)入Excel文件路徑 * @param outputFilePath 導(dǎo)出PDF文件路徑 */ public static void jacobExcelToPDF(String inputFilePath, String outputFilePath) { ActiveXComponent ax = null; Dispatch excel = null; ? try { ComThread.InitSTA(); ax = new ActiveXComponent("Excel.Application"); ax.setProperty("Visible", new Variant(false)); // 禁用宏 ax.setProperty("AutomationSecurity", new Variant(3)); ? Dispatch excels = ax.getProperty("Workbooks").toDispatch(); ? Object[] obj = { inputFilePath, new Variant(false), new Variant(false) }; ? excel = Dispatch.invoke(excels, "Open", Dispatch.Method, obj, new int[9]).toDispatch(); ? // 轉(zhuǎn)換格式 Object[] obj2 = { // PDF格式等于0 new Variant(0), outputFilePath, // 0=標(biāo)準(zhǔn)(生成的PDF圖片不會模糊),1=最小的文件 new Variant(0) }; ? Dispatch.invoke(excel, "ExportAsFixedFormat", Dispatch.Method, obj2, new int[1]); ? } catch (Exception e) { e.printStackTrace(); throw e; } finally { if (excel != null) { Dispatch.call(excel, "Close", new Variant(false)); } if (ax != null) { ax.invoke("Quit", new Variant[]{}); ax = null; } ComThread.Release(); } ? ? }
以上就是在Java中將Excel導(dǎo)出為PDF最常用的兩種方法了,推薦使用第二種!
到此這篇關(guān)于Java實現(xiàn)Excel轉(zhuǎn)PDF的兩種方法詳解的文章就介紹到這了,更多相關(guān)Java Excel轉(zhuǎn)PDF內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java中BigDecimal比較大小的3種方法(??compareTo()、??equals()??和??compar
這篇文章主要給大家介紹了關(guān)于Java中BigDecimal比較大小的3種方法,方法分別是??compareTo()、??equals()??和??compareTo()??,在Java中使用BigDecimal類來進(jìn)行精確的數(shù)值計算,需要的朋友可以參考下2023-11-11springboot+vue實現(xiàn)websocket配置過程解析
這篇文章主要介紹了springboot+vue實現(xiàn)websocket配置過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-04-04Java基礎(chǔ)之打印萬年歷的簡單實現(xiàn)(案例)
下面小編就為大家?guī)硪黄狫ava基礎(chǔ)之打印萬年歷的簡單實現(xiàn)(案例)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-07-07mybatis項目實現(xiàn)動態(tài)表名的三種方法
有時在開發(fā)過程中java代碼中的表名和數(shù)據(jù)庫的表名并不是一致的,此時我們就需要動態(tài)的設(shè)置表名,本文主要介紹了mybatis項目實現(xiàn)動態(tài)表名的三種方法,具有一定的參考價值,感興趣的可以了解一下2024-01-01vscode開發(fā)maven的javaweb項目并部署到tomcat及配置指南
這篇文章主要給大家介紹了關(guān)于vscode開發(fā)maven的javaweb項目并部署到tomcat及配置的相關(guān)資料,在vscode中創(chuàng)建maven項目,需要逐一操作下面的環(huán)節(jié),文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12