.Net C# 免费PDF合成软件

news/2025/4/21 9:23:45/

最近用到pdf合成,发现各种软件均收费啊,这个技术非常简单,别人写好的库一大把,这里用到了PDFsharp,项目地址Home of PDFsharp and MigraDoc Foundation

软件下载地址

https://download.csdn.net/download/g313105910/88014569

源码下载地址

https://download.csdn.net/download/g313105910/88014573

废话不多说,上WPF代码

<Window x:Class="mergePDF.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"xmlns:local="clr-namespace:mergePDF"mc:Ignorable="d"Title="PDF合成器,有顺序要求请用数字给文件命名,从小到大排序" Height="450" Width="800"><Grid><Grid.RowDefinitions><RowDefinition Height="10*"/><RowDefinition Height="33*"/></Grid.RowDefinitions><Grid.ColumnDefinitions><ColumnDefinition/></Grid.ColumnDefinitions><Button Content="合成" HorizontalAlignment="Left" Margin="737,0,0,0" VerticalAlignment="Center" Click="ButtonStart_Click" Height="19" Width="28"/><Button Content="选择目录" HorizontalAlignment="Left" Margin="675,0,0,0" VerticalAlignment="Center" Click="ButtonUrl_Click" Height="19" Width="52"/><TextBox x:Name="Url_Text" HorizontalAlignment="Left" Margin="60,0,0,0" TextWrapping="Wrap" Text="" VerticalAlignment="Center" Width="600" Height="17"/><Label Content="Url:" HorizontalAlignment="Left" Margin="25,0,0,0" VerticalAlignment="Center"/><TextBox x:Name="Info_Text" TextWrapping="Wrap" VerticalScrollBarVisibility="Visible"  Text="" Grid.Row="1"/></Grid>
</Window>
using FolderBrowserEx;
using PdfSharp.Pdf;
using PdfSharp.Pdf.IO;
using System;
using System.Collections.Generic;
using System.IO;
using System.Windows;namespace mergePDF
{/// <summary>/// Interaction logic for MainWindow.xaml/// </summary>public partial class MainWindow : Window{public MainWindow(){InitializeComponent();}private void ButtonStart_Click(object sender, RoutedEventArgs e){Info_Text.Text = string.Empty;CombinePdfFiles(Url_Text.Text);}public void CombinePdfFiles(string folderPath){try{//读取文件夹中的文件夹int fileCount = 0;int pageCount = 0;PdfDocument outPdfFile = new PdfDocument();List<string> fileNameList = new List<string>();List<string> fileError = new List<string>();fileNameList.Add("开始合并");foreach (var filename in Directory.GetFiles(folderPath)){if (System.IO.Path.GetExtension(filename) == ".pdf"){try{PdfDocument pdfFile = PdfReader.Open(filename, PdfDocumentOpenMode.Import);fileCount++;pageCount += pdfFile.PageCount;int pageIndex = 0;foreach (var pdfPage in pdfFile.Pages){outPdfFile.AddPage(pdfPage);pageIndex++;fileNameList.Add(string.Format("文件名:{0}\t\t\t\t第{1}页\t文件共有{2}页", System.IO.Path.GetFileName(filename), pageIndex, pdfFile.PageCount));}}catch (Exception ex){fileError.Add(System.IO.Path.GetFileName(filename));Info_Text.Text += ex.Message + "\r\n";}}}string combineResult = "";if (fileCount > 0){//导出pdf文件string timeTag = DateTime.Now.ToString("MMdd_HH_mm_ss");SavePdfFile(folderPath + "\\合并", timeTag + ".pdf", outPdfFile);fileNameList.Add(string.Format("共 {0} 个文件,共 {1} 页。", fileCount, pageCount));if (fileError.Count > 0){fileNameList.Add("合并失败文件:");foreach (string p in fileError){fileNameList.Add(p);}}SaveTxtFile(folderPath + "\\合并", timeTag + ".txt", fileNameList);}combineResult = string.Format("合并成功文件数量:{0}", fileCount);if (fileError.Count > 0){combineResult += "\r\n";combineResult += string.Format("合并失败文件数量:{0}", fileError.Count);}foreach(var str in fileNameList){Info_Text.Text += str + "\r\n"; ;}Info_Text.Text += combineResult + "\r\n"; }catch (Exception ex){Info_Text.Text+=ex.Message + "\r\n";}Info_Text.ScrollToEnd();}private void SavePdfFile(string folderPath, string fileName, PdfDocument pdfFile){if (!Directory.Exists(folderPath)){Directory.CreateDirectory(folderPath);}pdfFile.Save(folderPath + "\\" + fileName);}private void SaveTxtFile(string folderPath, string fileName, List<string> content){if (!Directory.Exists(folderPath)){Directory.CreateDirectory(folderPath);}string fileFullPath = folderPath + "\\" + fileName;if (!File.Exists(fileFullPath)){var newFile = File.CreateText(fileFullPath);newFile.Close();}using (StreamWriter sw = new StreamWriter(fileFullPath, true)){foreach (string line in content){sw.WriteLine(line);}sw.Close();}}private void ButtonUrl_Click(object sender, RoutedEventArgs e){FolderBrowserDialog folderBrowserDialog = new FolderBrowserDialog();folderBrowserDialog.Title = "Select a folder";//folderBrowserDialog.InitialFolder = @"C:\";folderBrowserDialog.AllowMultiSelect = false;if (folderBrowserDialog.ShowDialog() == System.Windows.Forms.DialogResult.OK){Url_Text.Text = folderBrowserDialog.SelectedFolder;}}}
}

使用方法->打开软件

选择目录

合成成功

合并后的文件和日志


http://www.ppmy.cn/news/1015545.html

相关文章

JavaSE_2.1——数组【概念、创建、内存分配】

今天是练习数组的第一天&#xff0c;后续继续 1、数组的定义以及声明 1.数组的定义&#xff1a;一组能够存储相同数据类型值的变量的集合 2.数组的赋值方式&#xff1a; New关键字:表示创建一个数组&#xff1b; &#xff08;1&#xff09;使用默认的初始值来初始化数组中…

人工智能进入到制造业后,可以带来哪些方面的新改变?

随着人工智能&#xff08;AI&#xff09;进入制造业&#xff0c;它有可能带来重大变化和改进。以下是人工智能可以给制造业带来的一些关键变化&#xff1a; 1.提高效率和生产力&#xff1a;人工智能可以通过分析大量数据并识别低效率来优化生产流程。它可以帮助简化制造运营、…

HP Microserver Gen8 Smart Array B120i阵列卡的一些试验和操作

声明&#xff1a;本实验只测试HP Microserver Gen8 Smart Array B120i板载阵列卡&#xff0c;不同阵列卡结果可能会不同&#xff0c;请谨慎操作&#xff0c;本人不对您操作后导致的任何数据丢失或者损失承担任何责任&#xff0c;文章仅供参考&#xff0c;操作前请做好备份。 合…

【OpenCV常用函数:轮廓检测+外接矩形检测】cv2.findContours()+cv2.boundingRect()

文章目录 1、cv2.findContours()2、cv2.boundingRect() 1、cv2.findContours() 对具有黑色背景的二值图像寻找白色区域的轮廓&#xff0c;因此一般都会先经过cvtColor()灰度化和threshold()二值化后的图像作为输入。 cv2.findContous(image, mode, method[, contours[, hiera…

SpringMVC的架构有什么优势?——控制器(三)

前言 「作者主页」&#xff1a;雪碧有白泡泡 「个人网站」&#xff1a;雪碧的个人网站 「推荐专栏」&#xff1a; ★java一站式服务 ★ ★ React从入门到精通★ ★前端炫酷代码分享 ★ ★ 从0到英雄&#xff0c;vue成神之路★ ★ uniapp-从构建到提升★ ★ 从0到英雄&#xff…

docker【安装、存储、镜像、仓库、网络、监控】

docker-0110.0.0.51docker-0210.0.0.52docker-0310.0.0.53 【1】docker安装 docker-01 [rootdocker-01 ~]# vim /etc/yum.conf [main] cachedir/var/cache/yum/$basearch/$releasever keepcache1 debuglevel2 logfile/var/log/yum.log exactarch1 obsoletes1 gpgcheck1 plugin…

个人玩具小程序商城制作攻略,不容错过

在如今的移动互联网时代&#xff0c;小程序成为了企业和个人开展业务的重要工具。如果你是一个小白用户&#xff0c;想要打造一个玩具小程序商城&#xff0c;但又没有编程基础&#xff0c;不用担心&#xff01;本文将通过乔拓云提供的简单操作步骤&#xff0c;教你如何轻松实现…

Excel表格(一)

1.单一栏的宽度和高度设置 2.大标题的跨栏居中 3.让单元格内的文字------自动适应 4.序号递增 5.货币符号 6.日期格式的选择 选到单元格&#xff0c;选中对应的日期格式 7.自动求和的计算 然后在按住回车键即可求出当前行的金额 点击自动求和 8.冻结表格栏 9.排序 1.单栏排序 …