文檔合并是一種高效文檔處理方式。如果能夠有一個方法能將多種不同類型的文檔合并成一種文檔格式,那么在文檔存儲管理上將為我們提供極大的便利。因此,本篇文章介紹了一種如何使用免費組件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