文档合并是一种高效文档处理方式。如果能够有一个方法能将多种不同类型的文档合并成一种文档格式,那么在文档存储管理上将为我们提供极大的便利。因此,本篇文章介绍了一种如何使用免费组件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