iTextSharp 合并多个PDF文件

下载并且引用 iTextSharp.dll 

引用命名空间:

using System.Collections.Generic;
using System.IO;
using iTextSharp.text;
using iTextSharp.text.pdf;



namespace Oil.Main.Utility
{
    class PdfHelper
    {
        ///
        /// 读取合并的pdf文件名称
        ///

        /// 目录
        /// 导出的路径
        public static void MergePDF(string Directorypath, string outpath)
        {
            List filelist2 = new List();
            System.IO.DirectoryInfo di2 = new System.IO.DirectoryInfo(Directorypath);
            FileInfo[] ff2 = di2.GetFiles("*.pdf");
            BubbleSort(ff2);
            foreach (FileInfo temp in ff2)
            {
                filelist2.Add(Directorypath + "\\" + temp.Name);
            }
            mergePDFFiles(filelist2, outpath);
            DeleteAllPdf(Directorypath);
        }


        ///
        /// 冒泡排序
        ///

        /// 文件名数组
        public static void BubbleSort(FileInfo[] arr)
        {
            for (int i = 0; i < arr.Length; i++)
            {
                for (int j = i; j < arr.Length; j++)
                {
                    if (arr[i].LastWriteTime > arr[j].LastWriteTime)//按创建时间(升序)
                    {
                        FileInfo temp = arr[i];
                        arr[i] = arr[j];
                        arr[j] = temp;
                    }
                }
            }
        }


        ///
        /// 合成pdf文件
        ///

        /// 文件名list
        /// 输出路径
        public static void mergePDFFiles(List fileList, string outMergeFile)
        {
            PdfReader reader;
            Rectangle rec = new Rectangle(1660, 1000);
            Document document = new Document(rec);
            PdfWriter writer = PdfWriter.GetInstance(document, new FileStream(outMergeFile, FileMode.Create));
            document.Open();
            PdfContentByte cb = writer.DirectContent;
            PdfImportedPage newPage;
            for (int i = 0; i < fileList.Count; i++)
            {
                reader = new PdfReader(fileList[i]);
                int iPageNum = reader.NumberOfPages;
                for (int j = 1; j <= iPageNum; j++)
                {
                    document.NewPage();
                    newPage = writer.GetImportedPage(reader, j);
                    cb.AddTemplate(newPage, 0, 0);
                }
            }
            document.Close();
        }


        ///
        /// 删除一个文件里所有的文件
        ///

        /// 文件夹路径
        public static void DeleteAllPdf(string Directorypath)
        {
            System.IO.DirectoryInfo di = new System.IO.DirectoryInfo(Directorypath);
            if (di.Exists)
            {
                FileInfo[] ff = di.GetFiles("*.pdf");
                foreach (FileInfo temp in ff)
                {
                    File.Delete(Directorypath + "\\" + temp.Name);
                }
            }
        }
    }

}

你可能感兴趣的:(C#,.net工具)