Java實現Excel轉PDF的兩種方法總結

      網友投稿 1152 2025-04-02

      hello,你好呀,我是灰小猿,一個超會寫bug的程序猿!

      使用具將Excel轉為PDF的方法有很多,在這里我給大家介紹兩種常用的方法,分別應對兩種不一樣的使用場景,接下來我在springboot環境下給大家做一下演示!

      一、使用spire轉化PDF

      首先介紹一種比較簡單的方法,這種方法可以使用短短的幾行代碼就可以將我們的Excel文件中的某一個sheet頁或者整個Excel文件轉為PDF格式,

      但是這種方法有一個缺點就是這個jar包是收費的,只能導出3個sheet頁,不適合有多個sheet頁的Excel文件的轉換。

      使用時首先在pom文件中導入workbook的所需依賴:

      e-iceblue spire.xls.free 2.2.0

      1、使用spire將整個Excel文件轉為PDF

      使用workbook導出整個Excel文件的代碼只需要兩步,我們可以直接看代碼示例:

      /** * 使用spire簡單整個Excel轉換為pdf * * @param inputFilePath Excel文件路徑 * @param outputFilePath 導出的PDF文件路徑 */ public static void totalExcelToPDF(String inputFilePath, String outputFilePath) { Workbook wb = new Workbook(); // 引入Excel文件 wb.loadFromFile(inputFilePath); // 導出PDF文件 wb.saveToFile(outputFilePath, FileFormat.PDF); }

      2、指定單個的sheet頁轉為PDF

      使用spire可以將指定單個sheet頁面轉為PDF格式輸出,在這里需要輸入指定的sheet頁的下標。代碼示例如下:

      /** * 使用spire將單個sheet轉成pdf * * @param inputFilePath Excel文件路徑 * @param outputFilePath 導出的PDF文件路徑 * @param sheetNum 導出的sheet頁下標 */ 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); //調用方法保存為PDF格式 sheet.saveToPdf(outputFilePath); }

      以上使用spire來實現Excel轉換PDF的方法雖然簡單,但是不適合于較大的Excel文件轉化,只適合有小于3個sheet頁的文件使用。

      所以在企業項目開發中,如果想要將大批量的Excel文件或sheet頁較多的Excel文件整體轉化為PDF格式的話,還是推薦使用下面這種方法,而且這種方法使用穩定還免費!

      二、使用jacob實現Excel轉PDF(推薦使用)

      1、環境準備

      在使用jacob之前需要做一些準備,首先需要去下載jacob的壓縮包jacob.zip ,-:https://sourceforge.net/projects/jacob-project/

      解壓之后,得到如下內容:

      Java實現Excel轉PDF的兩種方法總結

      如果你是64位系統就用 x64的dll,32位系統就用x86的dll。之后我們需要將dll文件放入放入你的jdk的bin目錄下,如下圖所示:

      這樣前期準備工作就做好了,

      接下來在在Maven中引入Jacob所需依賴:

      com.jacob jacob 1.19 system D:\DevInstall\jacob18,19\jacob-1.19\jacob.jar

      注意:上面依賴中標簽的值就是你的jacob.jar的具體路徑,這個改成自己剛才下載的對應的路徑就行了。

      2、執行導出PDF

      執行Excel導出PDF的方法如下:其中比較重要的地方進行了注釋,方法可以直接拿來用即可!

      /** * 使用jacob實現excel轉PDF * * @param inputFilePath 導入Excel文件路徑 * @param outputFilePath 導出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(); // 轉換格式 Object[] obj2 = { // PDF格式等于0 new Variant(0), outputFilePath, // 0=標準(生成的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導出為PDF最常用的兩種方法了,推薦使用第二種!

      我是灰小猿,我們下期見!

      Java

      版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。

      版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。

      上一篇:excel表格中怎樣自動填充序數?
      下一篇:Vue.directive指令實現按鈕級別權限控制
      相關文章
      亚洲sss综合天堂久久久| 亚洲一级黄色大片| 99亚洲男女激情在线观看| 国产.亚洲.欧洲在线| 亚洲国产精品综合一区在线| 91亚洲导航深夜福利| 亚洲av日韩综合一区在线观看| 国产∨亚洲V天堂无码久久久 | 亚洲国产精品VA在线观看麻豆| 亚洲一区二区三区无码中文字幕| 久久久久亚洲精品无码网址| 亚洲国产精品尤物yw在线| 亚洲视频在线一区二区| 久久激情亚洲精品无码?V| 亚洲综合熟女久久久30p| 亚洲人成网站在线播放vr| 亚洲精品国精品久久99热一| 日韩亚洲人成在线综合日本| 久久亚洲精品成人综合| 亚洲国产综合精品中文第一区 | 亚洲成av人片在线天堂无| 亚洲欧美日韩中文二区| 亚洲AV无码一区二区三区电影| 亚洲欧美在线x视频| 亚洲精品成人片在线观看| 亚洲日韩欧洲无码av夜夜摸| 亚洲av无码国产精品夜色午夜| 亚洲视频2020| 亚洲成人动漫在线观看| xxx毛茸茸的亚洲| 亚洲国产成人精品无码区花野真一| 国产亚洲精品美女| 国产成人精品日本亚洲专区61| 日本红怡院亚洲红怡院最新| 亚洲黄色在线电影| 亚洲一区二区三区四区视频| 亚洲欧洲AV无码专区| 亚洲国产黄在线观看| 亚洲熟妇无码另类久久久| 色播亚洲视频在线观看| 亚洲国产成人久久精品app|