目录
- 一、下载iTextSharp.dll
- 下载iTextSharp.www.devze.comdll
- 命名空间引入
- 二、界面设计
- 三、代码
- 全局变量
- 选择文件夹的按钮
- 确认合并的按钮
- 四、导出结果
- 五、完整源码
一、下载iTextSharp.dll
下载iTextSharp.dll
可使用联机方式或者文件下载方式。
命名空间引入
代码开始时引入了一些命名空间,这些命名空间包含了程序运行所需的类和方法。
- System、System.Collections.Generic、System.ComponentModel等是.NET框架的核心命名空间。
- iTextSharp.text 和 iTextSharp.text.pdf 是用于处理PDF文件的库。
- System.IO 是用于文件和目录操作的命名空间。
- Microsoft.Win32 是用于访问Windows注册表的命名空间。
- System.Diagnostics 是用于诊断和调试的命名空间。
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; using iTextSharp.text; using iTextSharp.text.pdf; using System.IO; using Microsoft.Win32; using System.Diagnostics;
二、界面设计
三、代码
全局变量
定义了三个静态字符串变量,用于存储上次选择的文件夹路径、输入文件夹路径和输出文件夹路径。
// 全局变量 private static string lastFolderPath = ""; // 记录上次选择文件夹的路径 private static string inputFolderPath = ""; // 输入文件夹路径 private static string outputFolderPath = ""; // 输出文件夹路径
选择文件夹的按钮
从Windows注册表中读取上次选择的文件夹路径。
显示一个文件夹选择对话框,让用户选择包含PDF文件的文件夹。如果用户选择了一个文件夹,将该路径存储在inputFolderPath变量中,并创建(如果不存在)一个名为"Output"的子文件夹作为输出路径。将选择的路径显示在文本框txtPath中。/// <summary> /// 按钮,选择文件夹路径 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void btnSelectPath_Click(object sender, EventArgs e) { // 读取上次选择的文件夹路径 string registryKey = "Software\\PDF合并"; // 用您自己的应用程序名称替换YourAppName if (Registry.CurrentUser.OpenSubKey(registryKey) != null) { lastFolderPath = Registry.CurrentUser.OpenSubKey(registryKey).GetValue("LastFolder") as string; } // 创建并显示一个选择文件夹的对话框 FolderBrowserDialog folderDialog = new FolderBrowserDialog(); folderDialog.Description = "选择包含PDF文件的文件夹:"; folderDialog.SelectedPath = lastFolderPath; // 设置默认路径为用户上次选择的文件夹 if (folderDialog.ShowDialog() == DialogResult.OK) { // 获取用户选择的文件夹路径 inputFolderPath = folderDialog.SelectedPath; // 创建输出文件夹路径(如果它不存在则创建它) outputFolderPath = Path.Combine(inputFolderPath, "Output"); if (!Directory.Exists(outputFolderPath)) { Directory.CreateDirectory(outputFolderPath); } } txtPath.Text = inputFolderPath; }
确认合并的按钮
简而言之,当用户点击“确认合并PDF”按钮时,此方法首先检查用户是否已选择了一个路径。如果没有,它会提示用户选择一个路径;如果已选择,它会调用一个方法来合并PDF文件,并显示一个消息告知用户合并已完成,然后打开导出的文件夹供用户查看。
/// <summary> /// 按钮,确认合并PDF /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void btnOK_Click(object sender, EventArgs e) { if (txtPath.Text == string.Empty) { MessagandroideBox.Show("请选择要合并的文件夹路径!"); } else { // 调用合并PDF的方法 MergePDFs(inputFolderPath, outputFolderPath, "123"); MessageBox.Show("合并完成!"); // 打开导出的文件夹路径 Process.Start(outputFolderPath); } }
- 合并PDF的处理函数定义方法:public void MergePDFs(string inputFolderPath, string outputFolderPath, string outputPdfName)获取输入文件夹中所有的PDF文件,并将它们存储在inputFiles字符串数组中。创建输出PDF文件的路径,使用Path.Combine方法将输出文件夹路径和输出PDF文件名称组合起来。创建一个新的文件流stream,并使用FileStream类以写入模式打开它,准备写入输出PDF文件。创建一个新的Document对象pdfDoc,表示输出PDF文件。创建一个新的PdfCopy对象pdf,用于将内容复制到输出PDF文件中。打开输出PDF文档以进行写入。遍历所有输入的PDF文件,并使用PdfReader对象读取每个PDF文件。对于每个输入的PDF文件,获取其页面数,并使用for循环遍历每个页面。将每个输入PDF文件的页面添加到输出PDF文件中。检查输出PDF文档是否为空,如果不为空则关闭它。关闭文件流。创建新输出PDF文件的完整路径。检查新输出文件是否已存在,如果已存在则删除它。将原输出文件移动到新位置并重命名为"AllPDF_Merged.pdf"。
/// <summary> /// 合并多个PDF文件为一个PDF文件 /// </summary> /// <param name="inputFolderPath"></param> /// <param name="outputFolderPath"></param> /// <param name="outputPdfName"></param> public void MergePDFs(string inputFolderPath, string outputFolderPath, string outputPdfName) { // 获取输入文件夹中所有的PDF文件 string[] inputFiles = Directory.GetFiles(inputFolderPath, "*.pdf"); // 创建输出PDF文件路径 string outputPdfPath = Path.Combine(outputFolderPath, outputPdfName); // 创建输出PDF文件 using (FileStream stream = new FileStream(outputPdfPath, FileMode.Create)) { Document pdfDoc = new Document(); PdfCopy pdf = new PdfCopy(pdfDoc, stream); pdfDoc.Open(); foreach (string file in inputFiles) { // 读取每个PDF文件并将其页面添加到输出PDF中 PdfReader reader = new PdfReader(file); int n = reader.NumberOfPages; for (int i = 1; i <= n; i++) { pdf.AddPage(pdf.GetImportedPage(reader, i)); } reader.Close(); } if (pdfDoc != null) pdfDoc.Close(); stream.Close(); } string newOutputPdfPath = Path.Combine(outputFolderPath, "AllPDF_Merged.pdf"); // 检查新输出文件是否已存在 if (File.Exists(newOutputPdfPath)) { // 如果已存在,则删除旧文件并创建新文件 File.Delete(newOutputPdfPath); } // 重命名输出PDF文件 File.Move(outputPdfPath, newOutputPdfPath); }
四、导出结果
可将一个文件夹内的所有PDF合并成一个PDF文件导出。
五、完整源码
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; using iTextSharp.text; using iTextSharp.text.pdf; using System.IO; using Microsoft.Win32; using System.Diagnostics; namespace PDF合并 { public partial class Form1 : Form { public Form1() { InitializeComponent(); } // 全局变量 private static string lastFolderPath = ""; // 记录上次选择文件夹的路径 private static string inputFolderPath = ""; // 输入文件夹路径 private static string outputFolderPath = ""; // 输出文件夹路径 /// <summary> /// 按钮,选择文件夹路径 /// </summary> /// <androidparam name="sender"></param> /// <param name="e"></param> private void btnSelectPath_Click(object sender, EventArgs e) { // 读取上次选择的文件夹路径 string registryKey = "Software\\PDF合并"; // 用您自己的应用程序名称替换YourAppName if (Registry.CurrentUser.OpenSubKey(registryKey) != null) { lastFolderPath = Registry.CurrentUser.OpenSubKey(registryKey).GetValue("LastFolder") as string; } // 创建并显示一个选择文件夹的对话框 FolderBrowserDialog folderDialog = new FolderBrowserDialog(); folderDialog.Description = "选择包含PDF文件的文件夹:"; folderDialog.SelectedPath = lastFolderPath; // 设置默认路径为用户上次选择的文件夹 if (folderDialog.ShowDialog() == DialogResult.OK) { // 获取用户选择的文件夹路径 inputFolderPath = folderDialog.SelectedPath; // 创建输出文件夹路径(如果它不存在则创建它) outputFolderPath = Path.Combine(inputFolderPath, "Output"); if (!Directory.Exists(outputFolderPath)) { Directory.CreateDirectory(outputFolderPath); www.devze.com } } txtPath.Text = inputFolderPath; } /// <summary> /// 按钮,确认合并PDF /LMaPFcA// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void btnOK_Click(object sender, EventArgs e) { if (txtPath.Text == string.Empty) { MessageBox.Show("请选择要合并的文件夹路径!"); } else { // 调用合并PDF的方法 MergePDFs(inputFolderPath, outputFolderPath, "123"); MessageBox.Show("合并完成!"); // 打开导出的文件夹路径 Process.Start(outputFolderPath); } } /// <summary> /// 合并多个PDF文件为一个PDF文件 /// </summary> /// <param name="inputFolderPath"></param> /// <param name="outputFolderPath"></param> /// <param name="outputPdfName"></param> public void MergePDFs(string inputFolderPath, string outputFolderPath, string outputPdfName) { // 获取输入文件夹中所有的PDF文件 string[] inputFiles = Directory.GetFiles(inputFolderPath, "*.pdf"); // 创建输出PDF文件路径 string outputPdfPath = Path.Combine(outputFolderPath, outputPdfName); // 创建输出PDF文件 using (FileStream stream = new FileStream(outputPdfPath, FileMode.Create)) { Document pdfDoc = new Document(); PdfCopy pdf = new PdfCopy(pdfDoc, stream); pdfDoc.Open(); foreach (string file in inputFiles) { // 读取每个PDF文件并将其页面添加到输出PDF中 PdfReader reader = new PdfReader(file); int n = reader.NumberOfPages; for (int i = 1; i <= n; i++) { pdf.AddPage(pdf.GetImportedPage(reader, i)); } reader.Close(); } if (pdfDoc != null) pdfDoc.Close(); stream.Close(); } string newOutputPdfPath = Path.Combine(outputFolderPath, "AllPDF_Merged.pdf"); // 检查新输出文件是否已存在 if (File.Exists(newOutputPdfPath)) { // 如果已存在,则删除旧文件并创建新文件 File.Delete(newOutputPdfPath); } // 重命名输出PDF文件 File.Move(outputPdfPath, newOutputPdfPath); } } }
到此这篇关于C#实现PDF合并的项目实践的文章就介绍到这了,更多相关C# PDF合并内容请搜索编程客栈(www.devze.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程客栈(www.devze.com)!
精彩评论