欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java實現(xiàn)Excel轉(zhuǎn)PDF的完整方案分享

 更新時間:2025年08月15日 09:07:13   作者:用戶372157426135  
在企業(yè)數(shù)據(jù)報表場景中,Excel轉(zhuǎn)PDF是實現(xiàn)文檔安全分發(fā)的剛需,本文主要和大家分享了如何使用Java自動化實現(xiàn)該流程,需要的小伙伴可以參考一下

在企業(yè)數(shù)據(jù)報表場景中,Excel轉(zhuǎn)PDF是實現(xiàn)文檔安全分發(fā)的剛需。傳統(tǒng)的Apache POI需配合PDFBox才能實現(xiàn)格式轉(zhuǎn)換,不僅開發(fā)流程復(fù)雜,還易出現(xiàn)樣式丟失、布局錯位等問題。這里分享Spire.XLS for Java方案,支持直接輸出高保真PDF,無需安裝Office環(huán)境,保留原表格的公式、圖表、樣式等核心元素。3行代碼即可完成基礎(chǔ)轉(zhuǎn)換。

一、開發(fā)環(huán)境準(zhǔn)備

必要環(huán)境

JDK 1.8+ (推薦JDK 17)

Maven項目(Gradle配置可參考官方文檔)

添加依賴

  <repositories>
    <repository>
        <id>com.e-iceblue</id>
        <name>e-iceblue</name>
        <url>https://repo.e-iceblue.com/nexus/content/groups/public/</url>
    </repository>
</repositories>
<dependencies>
    <dependency>
        <groupId>e-iceblue</groupId>
        <artifactId>spire.xls</artifactId>
        <version>15.7.7</version>
    </dependency>
</dependencies>

二、基礎(chǔ)轉(zhuǎn)換實現(xiàn)

2.1 完整工作簿轉(zhuǎn)PDF

import com.spire.xls.*;

public class ExcelToPDF {
    public static void main(String[] args) {
        // 加載Excel文件
        Workbook workbook = new Workbook();
        workbook.loadFromFile("財務(wù)報表.xlsx");        
        
        // 轉(zhuǎn)換為PDF,保留完整工作表
        workbook.saveToFile("output.pdf", FileFormat.PDF);
        
        // 釋放資源
        workbook.dispose();
    }
}

注意事項

  • 支持.xls.xlsx格式輸入
  • 若需禁止分頁,通過workbook.getConverterSetting().setSheetFitToPage(true)將頁面內(nèi)容縮放到1頁

2.2 精準(zhǔn)區(qū)域轉(zhuǎn)PDF

通過Worksheet.getPageSetup().setPrintArea()指定輸出范圍,避免全表冗余:

// 選取Sheet1
Worksheet sheet = workbook.getWorksheets().get(0);

// 選取Sheet1的A1到F20區(qū)域
sheet.getPageSetup().setPrintArea("A1:F20");

// 執(zhí)行區(qū)域轉(zhuǎn)換
sheet.saveToPdf("區(qū)域報表.pdf",);
參數(shù)配置方法推薦場景
頁面方向setOrientation()寬表(如橫向財務(wù)報表)
縮放比例setZoom()小字號內(nèi)容放大
邊距控制setTopMargin() (上邊距)最大化打印區(qū)域

三、企業(yè)級場景解決方案

3.1 批量轉(zhuǎn)換優(yōu)化

使用線程池+資源釋放提升吞吐量:

ExecutorService executor = Executors.newFixedThreadPool(4);
List<Path> excelFiles = getBatchFiles(); // 假設(shè)獲取批量文件路徑

for (Path file : excelFiles) {
    executor.execute(() -> {
        Workbook wb = new Workbook();
        try {
            wb.loadFromFile(file.toString());
            wb.saveToFile(file + ".pdf", FileFormat.PDF);
        } finally {
            wb.dispose(); // 必須釋放,避免內(nèi)存泄漏
        }
    });
}

3.2 動態(tài)水印與LOGO

通過頁眉插入企業(yè)標(biāo)識+日期

PageSetup page = sheet.getPageSetup();
page.setLeftHeader("&"Calibri"&12&KFF0000 " + 
                   LocalDate.now() + " 機(jī)密文件"); // 紅色字體水印

// 添加LOGO(需圖片本地路徑)
page.setLeftHeaderImage("logo.png");
page.setLeftHeader("&G"); // &G表示圖片占位符

四、實踐建議

異常處理清單

異常類型排查方向
FileNotFoundException檢查輸入路徑權(quán)限及空格轉(zhuǎn)義
OutOfMemoryError分批處理大文件,及時dispose

五、方法補(bǔ)充

Java實現(xiàn)Excel轉(zhuǎn)PDF的兩種方法

使用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>

使用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);
     }

指定單個的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(推薦使用)

環(huán)境準(zhǔn)備

在使用jacob之前需要做一些準(zhǔn)備,首先需要去下載jacob的壓縮包jacob.zip 

接下來在在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)的路徑就行了。

執(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();
         }
 ?
 ?
     }

到此這篇關(guān)于Java實現(xiàn)Excel轉(zhuǎn)PDF的完整方案分享的文章就介紹到這了,更多相關(guān)Java Excel轉(zhuǎn)PDF內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mybatis中string和date的轉(zhuǎn)換方式

    mybatis中string和date的轉(zhuǎn)換方式

    這篇文章主要介紹了mybatis中string和date的轉(zhuǎn)換方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Java異常處理 如何跟蹤異常的傳播路徑

    Java異常處理 如何跟蹤異常的傳播路徑

    這篇文章主要介紹了Java異常處理 如何跟蹤異常的傳播路徑,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-07-07
  • Java經(jīng)典算法匯總之選擇排序(SelectionSort)

    Java經(jīng)典算法匯總之選擇排序(SelectionSort)

    選擇排序也是比較簡單的一種排序方法,原理也比較容易理解,選擇排序在每次遍歷過程中只記錄下來最小的一個元素的下標(biāo),待全部比較結(jié)束之后,將最小的元素與未排序的那部分序列的最前面一個元素交換,這樣就降低了交換的次數(shù),提高了排序效率。
    2016-04-04
  • RateLimiter 源碼分析

    RateLimiter 源碼分析

    本文主要對ratelimiter的常用方法以及源碼進(jìn)行了分析解讀,具有一定參考價值,需要的朋友可以了解下。
    2017-09-09
  • 淺析java中常用的定時任務(wù)框架-單體

    淺析java中常用的定時任務(wù)框架-單體

    這篇文章主要帶大家了解常用的單體應(yīng)用定時任務(wù)框架以及掌握定時任務(wù)在單體中如何使用,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2021-12-12
  • Java8 Stream中間操作實例解析

    Java8 Stream中間操作實例解析

    這篇文章主要介紹了Java8 Stream中間操作實例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-12-12
  • Spring @value用法示例詳解

    Spring @value用法示例詳解

    這篇文章主要介紹了Spring-@value用法詳解,為了簡化讀取properties文件中的配置值,spring支持@value注解的方式來獲取,這種方式大大簡化了項目配置,提高業(yè)務(wù)中的靈活性,本文通過實例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2022-08-08
  • Spring中@Autowired、@Qualifier、@Resource注解的區(qū)別

    Spring中@Autowired、@Qualifier、@Resource注解的區(qū)別

    這篇文章主要介紹了Spring中@Autowired、@Qualifier、@Resource注解的區(qū)別,@Autowired 可以單獨(dú)使用,如果單獨(dú)使用,它將按類型裝配,因此,如果在容器中聲明了多個相同類型的bean,則會出現(xiàn)問題,因為 @Autowired 不知道要使用哪個bean來注入,需要的朋友可以參考下
    2023-11-11
  • idea中創(chuàng)建新類時自動添加注釋的實現(xiàn)

    idea中創(chuàng)建新類時自動添加注釋的實現(xiàn)

    在每次使用idea創(chuàng)建一個新類時,過了一段時間發(fā)現(xiàn)看不懂這個類是用來干嘛的,為了解決這個問題,我們可以設(shè)置在創(chuàng)建一個新類時自動添加注釋,幫助我們理解這個類的用處,本文主要介紹了在idea中創(chuàng)建新類時自動添加注釋的實現(xiàn),感興趣的可以了解一下
    2025-03-03
  • Java線程變量ThreadLocal源碼分析

    Java線程變量ThreadLocal源碼分析

    ThreadLocal用來提供線程內(nèi)部的局部變量,不同的線程之間不會相互干擾,這種變量在多線程環(huán)境下訪問時能保證各個線程的變量相對獨(dú)立于其他線程內(nèi)的變量,在線程的生命周期內(nèi)起作用,可以減少同一個線程內(nèi)多個函數(shù)或組件之間一些公共變量傳遞的復(fù)雜度
    2022-08-08

最新評論