博客 / 詳情

返回

如何通過 C# 將 PPT 文檔轉換為 PDF 格式

在日常開發和辦公場景中,將 PowerPoint(PPT/PPTX) 轉換為 PDF 格式是高頻需求。PDF 格式具有跨平台兼容性強、格式固定不易篡改、便於分發歸檔等優勢。本文將介紹如何使用一款 .NET PowerPoint 組件通過 C# 實現 PPT 轉 PDF,並提供完整代碼示例。

1. 安裝 .NET 庫

Spire.Presentation 是一款專門用於處理 PowerPoint 文檔的 .NET 組件,無需依賴 Microsoft Office 或 PowerPoint 客户端即可完成 PPT 文檔的讀取、編輯和格式轉換。推薦通過 NuGet 包管理器安裝,步驟如下:

  1. 打開 Visual Studio,創建任意 C# 項目(如Console App);
  2. 右鍵項目→“管理NuGet程序包”;
  3. 搜索“Spire.Presentation”,選擇對應版本安裝;
  4. 也可通過NuGet命令行安裝:
Install-Package Spire.Presentation

2. 基礎示例:單個 PowerPoint 文件轉 PDF

這是最常用的場景,支持 PPT/PPTX 格式輸入,直接通過 SaveToFile 方法輸出為 PDF 文件:

using System;
using Spire.Presentation;

namespace PptToPdfDemo
{
    class Program
    {
        static void Main(string[] args)
        {
            try
            {
                // 1. 定義文件路徑
                string pptFilePath = @"D:\Demo\source.pptx"; // 輸入PPT路徑
                string pdfFilePath = @"D:\Demo\output.pdf";   // 輸出PDF路徑

                // 2. 加載PPT文檔
                Presentation presentation = new Presentation();
                presentation.LoadFromFile(pptFilePath);

                // 3. 轉換為PDF並保存
                // 可選參數:PDF導出選項(如壓縮、權限等),此處使用默認配置
                presentation.SaveToFile(pdfFilePath, FileFormat.PDF);

                // 4. 釋放資源(關鍵,避免內存泄漏)
                presentation.Dispose();

                Console.WriteLine("PPT轉PDF成功!");
            }
            catch (Exception ex)
            {
                // 異常處理:捕獲文件不存在、格式不支持、權限不足等問題
                Console.WriteLine($"轉換失敗:{ex.Message}");
            }
        }
    }
}

3. 批量轉換:轉換多個 PowerPoint 文件為 PDF

通過遍歷文件夾實現批量轉換,適合處理大量 PPT 文件:

using System;
using System.IO;
using Spire.Presentation;

namespace BatchPptToPdf
{
    class Program
    {
        static void Main(string[] args)
        {
            // 源PPT文件夾路徑
            string pptFolderPath = @"D:\Demo\PptFiles";
            // 輸出PDF文件夾路徑
            string pdfFolderPath = @"D:\Demo\PdfFiles";

            // 確保輸出文件夾存在
            if (!Directory.Exists(pdfFolderPath))
            {
                Directory.CreateDirectory(pdfFolderPath);
            }

            // 遍歷文件夾中的PPT/PPTX文件
            string[] pptFiles = Directory.GetFiles(pptFolderPath, "*", SearchOption.TopDirectoryOnly)
                .Where(file => file.EndsWith(".ppt", StringComparison.OrdinalIgnoreCase) 
                             || file.EndsWith(".pptx", StringComparison.OrdinalIgnoreCase))
                .ToArray();

            foreach (string pptFile in pptFiles)
            {
                try
                {
                    // 獲取文件名(不含擴展名),用於生成PDF文件名
                    string fileName = Path.GetFileNameWithoutExtension(pptFile);
                    string pdfFile = Path.Combine(pdfFolderPath, $"{fileName}.pdf");

                    // 加載並轉換
                    using (Presentation presentation = new Presentation())
                    {
                        presentation.LoadFromFile(pptFile);
                        presentation.SaveToFile(pdfFile, FileFormat.PDF);
                    }

                    Console.WriteLine($"已轉換:{pptFile} → {pdfFile}");
                }
                catch (Exception ex)
                {
                    Console.WriteLine($"轉換失敗 {pptFile}:{ex.Message}");
                }
            }

            Console.WriteLine("批量轉換完成!");
        }
    }
}

4. 進階示例:將 PowerPoint 轉換為加密的 PDF

還可以在轉換時直接加密保護 PDF 文件,併為 PDF 設置權限:

using Spire.Presentation;
using Spire.Presentation.External.Pdf;

namespace ConvertToEncryptedPdf
{
    class Program
    {
        static void Main(string[] args)
        {
            // 定義明確的文件路徑(建議替換為你的實際路徑)
            string inputPptPath = @"C:\Users\Administrator\Desktop\Input.pptx";
            string outputPdfPath = @"C:\Users\Administrator\Desktop\ToEncryptedPdf.pdf";
            
            // 使用using語句自動釋放Presentation資源(優於手動Dispose)
            try
            {
                using (Presentation presentation = new Presentation())
                {
                    // 加載PPT文件
                    presentation.LoadFromFile(inputPptPath);

                    // 獲取PDF保存選項
                    SaveToPdfOption option = presentation.SaveToPdfOption;
                    
                    // 設置PDF密碼和權限
                    // 參數説明:
                    // 1. 用户密碼(打開PDF需要輸入的密碼):abc-123
                    // 2. 所有者密碼(用於修改PDF權限的密碼):owner-456(可自定義)
                    // 3. PDF權限:允許打印 + 允許填寫表單
                    // 4. 加密級別:默認128位(高安全性)
                  option.PdfSecurity.Encrypt("abc-123", "owner-456", 
                        PdfPermissionsFlags.Print | PdfPermissionsFlags.FillFields, 
                        PdfEncryptionKeySize.Key128Bit);

                    // 保存為加密PDF
                    presentation.SaveToFile(outputPdfPath, FileFormat.PDF, pdfOptions);

                    Console.WriteLine("PPT已成功轉換為加密PDF!");
                    Console.WriteLine($"輸出路徑:{outputPdfPath}");
                }
            }
            catch (Exception ex)
            {
                // 捕獲所有可能的異常並提示
                Console.WriteLine($"轉換失敗:{ex.Message}");
            }

            // 暫停控制枱,便於查看結果
            Console.ReadLine();
        }
    }
}

5. 關鍵注意事項

  1. 格式兼容性

    • 支持輸入格式:PPT、PPTX、PPS、PPSX 等;
    • 複雜PPT元素(如3D圖表、自定義動畫、嵌入式視頻)轉換後可能丟失或顯示異常(。
  2. 資源釋放

    • 必須通過 Dispose() 方法釋放 Presentation 對象,或使用 using 語句(推薦),否則易導致內存泄漏,尤其批量轉換時需注意。
  3. 權限問題

    • 確保程序對輸入/輸出路徑有讀寫權限,否則會拋出 UnauthorizedAccessException

6. 替代方案參考

  1. LibreOffice SDK:免費開源,需部署 LibreOffice 服務,API 較複雜;
  2. OpenXML SDK + iTextSharp:僅支持 PPTX(OpenXML 格式),需自行處理佈局轉換,開發成本高;
  3. GroupDocs.Conversion:有免費額度,雲原生支持,但依賴網絡。

本文提供了可靠的 C# PowerPoint 轉 PDF 解決方案,特別適合在服務器環境或無需安裝 Microsoft Office 的場景中使用。其優點包括部署簡單、API 設計清晰、支持多種輸出選項等。

user avatar
0 位用戶收藏了這個故事!

發佈 評論

Some HTML is okay.