每個工作表一頁:使用 GroupDocs.Conversion 在 Java 中自動將試算表轉換為 PDF

介紹

如果你已厭倦手動將試算表轉換成 PDF,這裡正是你需要的地方。在本教學中,我們將示範 GroupDocs.Conversion for Java 如何 自動化試算表轉換,並提供細緻的控制——例如僅載入所需的列,並產生 每個工作表一頁 的 PDF 輸出。完成後,你將了解如何:

  • 載入活頁簿時指定儲存格範圍
  • 設定轉換器,使每個工作表成為單一 PDF 頁面
  • 使用最新的 GroupDocs.Conversion 函式庫設定 Java 專案

在深入程式碼之前,先把環境準備好。

快速解答

  • 「每個工作表一頁」是什麼意思? 來源 Excel 檔案中的每個工作表會在產生的 PDF 中呈現為單一頁面。
  • 哪個函式庫負責轉換? GroupDocs.Conversion for Java(版本 25.2)。
  • 我需要授權嗎? 免費試用版可用於評估;在正式環境中需要臨時或購買授權。
  • 我能有效率地轉換大型試算表嗎? 可以——只載入所需範圍即可減少記憶體使用並加快處理速度。
  • 需要哪個 Java 版本? JDK 8 或更新版本。

什麼是「每個工作表一頁」?

當你轉換 Excel 活頁簿時,預設行為可能會為每個工作表產生多個 PDF 頁面(每個列印區域一頁)。啟用 每個工作表一頁 選項會強制轉換器將整個工作表壓縮至單一 PDF 頁面,這對於報告、簡報,或需要可預測頁數的情況特別適合。

為什麼使用 GroupDocs.Conversion for Java?

  • 強大的格式支援 – 支援 XLS、XLSX、CSV 以及許多其他試算表類型。
  • 高效能 – 載入選項讓你只針對需要的資料,適合大型檔案。
  • 簡易 API – 只需幾行 Java 程式碼即可產生可投入生產的 PDF。
  • 跨平台 – 只要有 Java 的環境皆可執行,從桌面應用到雲端服務皆適用。

前置條件

  • Java Development Kit (JDK) 8+ 已安裝
  • Maven 用於相依管理
  • IntelliJ IDEAEclipse 等 IDE
  • 基本的 Java 知識以及熟悉 Maven 專案結構

設定 GroupDocs.Conversion for Java

Maven 設定

將 GroupDocs 儲存庫與轉換相依項目加入你的 pom.xml

<repositories>
   <repository>
      <id>repository.groupdocs.com</id>
      <name>GroupDocs Repository</name>
      <url>https://releases.groupdocs.com/conversion/java/</url>
   </repository>
</repositories>

<dependencies>
   <dependency>
      <groupId>com.groupdocs</groupId>
      <artifactId>groupdocs-conversion</artifactId>
      <version>25.2</version>
   </dependency>
</dependencies>

取得授權步驟

  • 免費試用:下載試用版以測試功能。
  • 臨時授權:在開發期間申請臨時授權以取得完整功能。
  • 購買:長期使用時,請從 GroupDocs 網站 購買授權。

加入相依項目後,即可開始使用 API:

import com.groupdocs.conversion.Converter;
// Basic initialization code here...

載入特定範圍的試算表

為什麼要載入範圍?

僅載入所需的列(例如第 10‑30 列)可加快轉換速度並降低記憶體消耗——在 convert large spreadsheet pdf(轉換大型試算表 PDF)檔案時特別有幫助。

實作

import com.groupdocs.conversion.options.load.SpreadsheetLoadOptions;

public class FeatureLoadSpreadsheetWithRange {
    public static void run() {
        // Create load options for specifying a range of cells
        SpreadsheetLoadOptions loadOptions = new SpreadsheetLoadOptions();
        
        // Specify the cell range (e.g., "10:30" means rows 10 to 30)
        loadOptions.setConvertRange("10:30");
    }
}

setConvertRange 方法告訴轉換器忽略定義列之外的所有內容,使 java convert excel pdf 操作更快且更精簡。

以每個工作表一頁方式將試算表轉換為 PDF

此選項如何運作

設定 setOnePagePerSheet(true) 會指示引擎將每個工作表渲染至單一 PDF 頁面,無論其原始列印區域如何。這正是 one page per sheet(每個工作表一頁)需求的核心。

實作

import com.groupdocs.conversion.Converter;
import com.groupdocs.conversion.options.convert.PdfConvertOptions;

public class FeatureConvertToPdfWithOnePagePerSheet {
    public static void run() {
        // Initialize load options with one-page-per-sheet setting
        SpreadsheetLoadOptions loadOptions = new SpreadsheetLoadOptions();
        loadOptions.setOnePagePerSheet(true);
        
        // Initialize the Converter object with your document path and load options
        Converter converter = new Converter("YOUR_DOCUMENT_DIRECTORY/sample.xlsx", () -> loadOptions);
        
        // Configure PDF conversion to produce one page per sheet
        PdfConvertOptions pdfOptions = new PdfConvertOptions();
        
        // Execute the conversion process
        converter.convert("YOUR_OUTPUT_DIRECTORY/ConvertedSpreadsheet.pdf", pdfOptions);
    }
}

現在 sample.xlsx 中的每個工作表都會在 ConvertedSpreadsheet.pdf 中變成單一頁面。

實務應用

情境功能如何協助
財務報告僅載入包含季報數字的列,為每個部門產生整潔的每個工作表一頁 PDF。
學術出版轉換研究資料表,聚焦相關範圍,確保每張工作表各自列印於單獨頁面,方便引用。
商業簡報產生可直接用於簡報的 PDF,每張投影片對應一個工作表,得益於每個工作表一頁的設定。

效能考量

  • 縮小轉換範圍 – 使用 setConvertRange 限制列/欄。
  • 釋放資源 – 關閉串流,並在轉換完成後讓 Converter 超出範圍以釋放。
  • 平行處理 – 對於批次作業,可在獨立執行緒上執行轉換,以保持 UI 響應。

常見問題

Q: 使用 GroupDocs.Conversion 需要的最低 Java 版本是什麼?
A: 建議使用 JDK 8 或更高版本以確保相容性。

Q: 我可以一次轉換多種試算表格式嗎?
A: 可以,GroupDocs.Conversion 支援 Excel、CSV 以及許多其他格式。

Q: 我要如何取得臨時授權以取得完整功能?
A: 可透過 GroupDocs 網站 申請。

Q: 如果我的試算表太大,無法在記憶體中轉換,該怎麼辦?
A: 使用 setConvertRange 僅載入所需範圍,並考慮在轉換過程中將檔案串流至磁碟。

Q: 我能將 GroupDocs.Conversion 與雲端儲存服務整合嗎?
A: 可以,您可以使用標準的 Java I/O 串流讀寫 AWS S3、Azure Blob Storage、Google Cloud Storage 等服務。

資源


最後更新: 2026-02-05
測試版本: GroupDocs.Conversion 25.2 for Java
作者: GroupDocs