文档合并是一种高效文档处理方式。如果能够有一个方法能将多种不同类型的文档合并成一种文档格式,那么在文档存储管理上将为我们提供极大的便利。因此,本篇文章介绍了一种如何使用免费组件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 指令:
1
2
3
4
|
using spire.doc;
using spire.xls;
using spire.pdf;
using system.io;
|
文档合并前:
主要代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
//声明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文档为一个文件,可参见这篇文章c#实现合并及拆分pdf文件的方法。
原文链接:https://www.cnblogs.com/Yesi/archive/2018/01/18/8310481.html