C# 合并多种格式文件为PDF
文档合并是一种高效文档处理方式。如果能够有一个方法能将多种不同类型的文档合并成一种文档格式,那么在文档存储管理上将为我们提供极大的便利。因此,本篇文章介绍了一种如何使用免费组件Free Spire.Office for .NET来实现将多种各式的文档合并为PDF的方法。本方法中可合并的文档格式可以是doc、docx、xls、xlsx、pdf等。下面将进行详细阐述。
使用方法:安装Free Spire.Office for .NET后,添加引用spire.doc.dll, spire.xls.dll, spire.pdf.dll三个文件,如下图所示:
添加以后,在命名空间添加如下using 指令:
using Spire.Doc; using Spire.Xls; using Spire.Pdf; using System.IO;
文档合并前:
主要代码:
//声明PdfDocument对象数组 PdfDocument[] documents = new PdfDocument[4]; using (MemoryStream ms1 = new MemoryStream()) { //加载doc文档 Document doc = new Document(@"C:\Users\Administrator\Desktop\sample.doc", Spire.Doc.FileFormat.Doc); //转换PDF,并以流的形式保存 doc.SaveToStream(ms1, Spire.Doc.FileFormat.PDF); //加载PDF流文件为PdfDocument对象数组的第一个元素 documents[0] = new PdfDocument(ms1); } using (MemoryStream ms2 = new MemoryStream()) { //加载docx文档 Document docx = new Document(@"C:\Users\Administrator\Desktop\test.docx", Spire.Doc.FileFormat.Docx2010); //转换PDF,并以流的形式保存 docx.SaveToStream(ms2, Spire.Doc.FileFormat.PDF); //加载PDF流文件为PdfDocument对象数组的第二个元素 documents[1] = new PdfDocument(ms2); } using (MemoryStream ms3 = new MemoryStream()) { //加载xlsx文档 Workbook workbook = new Workbook(); workbook.LoadFromFile(@"C:\Users\Administrator\Desktop\Sample.xlsx", ExcelVersion.Version97to2003); //转换PDF,并以流的形式保存 workbook.SaveToStream(ms3, Spire.Xls.FileFormat.PDF); //加载PDF流文件为PdfDocument对象数组的第三个元素 documents[2] = new PdfDocument(ms3); } //加载pdf文档,作为PdfDocument对象数组的第四个元素 documents[3] = new PdfDocument(@"C:\Users\Administrator\Desktop\sample.pdf"); //将前三个文档合并到第四个文档,并另存为新的PDF文档 for (int i = 2; i > -1; i--) { documents[3].AppendPage(documents[i]); } documents[3].SaveToFile("Result.pdf");
完成代码后,调试运行该项目,生成文件。
合并效果展示:
以上全部内容为合并不同格式文件为PDF文件的方法,如果想合并多个单一格式的PDF文档为一个文件,可参见这篇文章:http://www.cnblogs.com/Yesi/p/5604166.html 。
如果喜欢本文,欢迎转载(转载请注明出处)
感谢浏览!
分类:
.NET OFFICE
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· 上周热点回顾(2.17-2.23)
· 如何使用 Uni-app 实现视频聊天(源码,支持安卓、iOS)
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)