在 C# 项目中,将 Word 文档转换为 PDF 是常见需求。可以使用 Microsoft 提供的 Microsoft.Office.Interop.Word
,也可以选择功能更强且不依赖于 Microsoft Word 安装的第三方库。本文记录了这两种实现方式,特别推荐使用 Aspose.Words
,适合需要跨平台或服务器环境部署的场景。
一、使用 Microsoft.Office.Interop.Word
示例代码
using System;
using Microsoft.Office.Interop.Word;
namespace WordToPdfConverter
{
class Program
{
static void Main(string[] args)
{
Application wordApp = new Application();
wordApp.Visible = false;
string sourcePath = @"C:\path\to\your\document.docx";
string targetPath = @"C:\path\to\your\document.pdf";
try
{
Document wordDoc = wordApp.Documents.Open(sourcePath);
wordDoc.ExportAsFixedFormat(targetPath, WdExportFormat.wdExportFormatPDF);
wordDoc.Close(WdSaveOptions.wdDoNotSaveChanges);
Console.WriteLine("Conversion successful!");
}
catch (Exception ex)
{
Console.WriteLine("Error: " + ex.Message);
}
finally
{
wordApp.Quit();
}
}
}
}
注意事项
- 需要安装 Microsoft Word,因为
Microsoft.Office.Interop.Word
依赖于 Word 程序。 - 确保在项目中添加对
Microsoft.Office.Interop.Word
的引用。
这种方法适合本地开发环境,但不适合服务器等没有 Office 环境的场景。
二、使用 Aspose.Words
如果需要跨平台支持或在服务器上运行,可以使用第三方库 Aspose.Words
,无需安装 Microsoft Word。
安装
在项目中通过 NuGet 安装 Aspose.Words:
Install-Package Aspose.Words
示例代码
using System;
using Aspose.Words;
namespace WordToPdfConverter
{
class Program
{
static void Main(string[] args)
{
string sourcePath = @"C:\path\to\your\document.docx";
string targetPath = @"C:\path\to\your\document.pdf";
try
{
Document doc = new Document(sourcePath);
doc.Save(targetPath, SaveFormat.Pdf);
Console.WriteLine("Conversion successful!");
}
catch (Exception ex)
{
Console.WriteLine("Error: " + ex.Message);
}
}
}
}
优势
- 无需安装 Microsoft Word,特别适合服务器部署。
- 支持多种格式的文档处理。
注意
Aspose.Words
是商业软件,免费试用有一定限制,商业用途需购买许可证。
总结
在 C# 中,将 Word 转换为 PDF 可以通过 Microsoft.Office.Interop.Word
或 Aspose.Words
实现:
- 如果开发环境安装了 Microsoft Word,并且项目只在本地运行,可选择
Microsoft.Office.Interop.Word
。 - 如果需要跨平台、云端或服务器部署,更推荐使用
Aspose.Words
,避免 Word 安装的限制。
根据实际项目需求选择合适的方法,提升开发效率与系统稳定性。