Java實(shí)現(xiàn)Excel轉(zhuǎn)PDF的兩種方法詳解
使用具將Excel轉(zhuǎn)為PDF的方法有很多,在這里我給大家介紹兩種常用的方法,分別應(yīng)對(duì)兩種不一樣的使用場(chǎng)景,接下來(lái)我在springboot環(huán)境下給大家做一下演示!
一、使用spire轉(zhuǎn)化PDF
首先介紹一種比較簡(jiǎn)單的方法,這種方法可以使用短短的幾行代碼就可以將我們的Excel文件中的某一個(gè)sheet頁(yè)或者整個(gè)Excel文件轉(zhuǎn)為PDF格式,
但是這種方法有一個(gè)缺點(diǎn)就是這個(gè)jar包是收費(fèi)的,只能導(dǎo)出3個(gè)sheet頁(yè),不適合有多個(gè)sheet頁(yè)的Excel文件的轉(zhuǎn)換。
使用時(shí)首先在pom文件中導(dǎo)入workbook的所需依賴:
         <dependency>
             <groupId>e-iceblue</groupId>
             <artifactId>spire.xls.free</artifactId>
             <version>2.2.0</version>
         </dependency>1、使用spire將整個(gè)Excel文件轉(zhuǎn)為PDF
使用workbook導(dǎo)出整個(gè)Excel文件的代碼只需要兩步,我們可以直接看代碼示例:
     /**
      * 使用spire簡(jiǎn)單整個(gè)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、指定單個(gè)的sheet頁(yè)轉(zhuǎn)為PDF
使用spire可以將指定單個(gè)sheet頁(yè)面轉(zhuǎn)為PDF格式輸出,在這里需要輸入指定的sheet頁(yè)的下標(biāo)。代碼示例如下:
     /**
      * 使用spire將單個(gè)sheet轉(zhuǎn)成pdf
      *
      * @param inputFilePath Excel文件路徑
      * @param outputFilePath 導(dǎo)出的PDF文件路徑
      * @param sheetNum 導(dǎo)出的sheet頁(yè)下標(biāo)
      */
     public static void partExcelToPDF(String inputFilePath, String outputFilePath, int sheetNum) {
         //加載Excel文檔
         Workbook wb = new Workbook();
         wb.loadFromFile(inputFilePath);
         //獲取到哪一個(gè)sheet頁(yè)
         Worksheet sheet = wb.getWorksheets().get(sheetNum);
         //調(diào)用方法保存為PDF格式
         sheet.saveToPdf(outputFilePath);
     }以上使用spire來(lái)實(shí)現(xiàn)Excel轉(zhuǎn)換PDF的方法雖然簡(jiǎn)單,但是不適合于較大的Excel文件轉(zhuǎn)化,只適合有小于3個(gè)sheet頁(yè)的文件使用。
所以在企業(yè)項(xiàng)目開(kāi)發(fā)中,如果想要將大批量的Excel文件或sheet頁(yè)較多的Excel文件整體轉(zhuǎn)化為PDF格式的話,還是推薦使用下面這種方法,而且這種方法使用穩(wěn)定還免費(fèi)!
二、使用jacob實(shí)現(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)備工作就做好了,
接下來(lái)在在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的具體路徑,這個(gè)改成自己剛才下載的對(duì)應(yīng)的路徑就行了。
2、執(zhí)行導(dǎo)出PDF
執(zhí)行Excel導(dǎo)出PDF的方法如下:其中比較重要的地方進(jìn)行了注釋,方法可以直接拿來(lái)用即可!
 ?
     /**
      * 使用jacob實(shí)現(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圖片不會(huì)模糊),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實(shí)現(xiàn)Excel轉(zhuǎn)PDF的兩種方法詳解的文章就介紹到這了,更多相關(guān)Java Excel轉(zhuǎn)PDF內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
 Springboot居然可以設(shè)置動(dòng)態(tài)的Banner(推薦)
這篇文章主要介紹了Springboot居然可以設(shè)置動(dòng)態(tài)的Banner,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03
 Java實(shí)現(xiàn)自動(dòng)壓縮文件并加密的方法示例
這篇文章主要介紹了Java實(shí)現(xiàn)自動(dòng)壓縮文件并加密的方法,涉及java針對(duì)文件進(jìn)行zip壓縮并加密的相關(guān)操作技巧,需要的朋友可以參考下2018-01-01
 一天時(shí)間用Java寫(xiě)了個(gè)飛機(jī)大戰(zhàn)游戲,朋友直呼高手
前兩天我發(fā)現(xiàn)論壇有兩篇飛機(jī)大戰(zhàn)的文章異?;鸨?但都是python寫(xiě)的,竟然不是我大Java,說(shuō)實(shí)話作為老java選手,我心里是有那么一些失落的,今天特地整理了這篇文章,需要的朋友可以參考下2021-05-05
 MybatisPlus實(shí)現(xiàn)數(shù)據(jù)攔截的使用示例
在MyBatis-Plus中,可以通過(guò)自定義攔截器來(lái)實(shí)現(xiàn)對(duì)SQL語(yǔ)句的攔截和修改,本文就來(lái)介紹一下如何使用,具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10
 Java之Spring簡(jiǎn)單的讀取和存儲(chǔ)對(duì)象
這篇文章主要介紹了Spring的讀取和存儲(chǔ)對(duì)象,獲取 bean 對(duì)象也叫做對(duì)象裝配,是把對(duì)象取出來(lái)放到某個(gè)類中,有時(shí)候也叫對(duì)象注?,想進(jìn)一步了解的同學(xué)可以參考本文2023-04-04
 java實(shí)現(xiàn)代碼統(tǒng)計(jì)小程序
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)代碼統(tǒng)計(jì)小程序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09
 MyBatis動(dòng)態(tài)<if>標(biāo)簽使用避坑指南
這篇文章主要為大家介紹了MyBatis動(dòng)態(tài)<if>標(biāo)簽使用避坑指南,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03
 Java使用httpRequest+Jsoup爬取紅藍(lán)球號(hào)碼
本文將結(jié)合實(shí)例代碼,介紹Java使用httpRequest+Jsoup爬取紅藍(lán)球號(hào)碼,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-07-07
 SpringBoot整合Ehcache3的實(shí)現(xiàn)步驟
本文主要介紹了SpringBoot整合Ehcache3的實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01

