使用 iTextSharp 在 .NET Core 中进行 PDF 管理之合并 PDF

介绍

在当今的数字时代,以编程方式管理 PDF 文档是许多应用程序的常见要求。无论是生成报告和发票还是合并多个 PDF 文件,拥有合适的工具都可以显著简化开发流程。在本文中,我们将探讨如何利用 iTextSharp(一种用于处理 C# 中 PDF 的流行库)在 .NET Core 应用程序中无缝合并 PDF 文件。

iTextSharp 是一个功能强大的库,用于在 C# 中创建和操作 PDF 文档。它提供了一套全面的功能,用于读取、写入和修改 PDF 文件。借助 iTextSharp,开发人员可以轻松生成动态 PDF 内容、添加注释、加密文档等等。

设置环境

首先,请确保您的开发机器上安装了 .NET Core。您可以使用您喜欢的 IDE 或命令行创建一个新的 .NET Core 项目。

接下来,通过在包管理器控制台中运行以下命令将 iTextSharp NuGet 包添加到您的项目中:

dotnet add package itext7

此命令将把最新版本的 iTextSharp 及其依赖项安装到您的项目中。

合并 PDF 文件

现在我们已经设置好了环境,让我们深入研究合并 PDF 文件。下面是一个简单的示例,演示如何使用 iTextSharp 合并两个 PDF 文件:

// 引入 iText.Kernel.Pdf 命名空间
using iText.Kernel.Pdf;
// 引入 iText.Kernel.Utils 命名空间
using iText.Kernel.Utils;

// 定义 Program 类
class Program
{
    // 定义 Main 方法,程序入口
    static void Main(string[] args)
    {
        // 要合并的 PDF 文件数组
        string[] filesToMerge = { "file1.pdf", "file2.pdf" };
        // 合并后的 PDF 文件名
        string mergedFile = "merged.pdf";

        // 使用 PdfWriter 创建写入流,生成合并后的 PDF 文件
        using (PdfWriter writer = new PdfWriter(mergedFile))
        {
            // 创建 PdfDocument 实例,用于合并后的 PDF 文件
            using (PdfDocument pdf = new PdfDocument(writer))
            {
                // 创建 PdfMerger 实例,执行 PDF 合并操作
                PdfMerger merger = new PdfMerger(pdf);

                // 遍历要合并的 PDF 文件数组
                foreach (string file in filesToMerge)
                {
                    // 使用 PdfReader 打开每个源 PDF 文件
                    PdfDocument sourcePdf = new PdfDocument(new PdfReader(file));
                    // 将源 PDF 文件的所有页面合并到目标 PDF 文件
                    merger.Merge(sourcePdf, 1, sourcePdf.GetNumberOfPages());
                    // 关闭源 PDF 文件
                    sourcePdf.Close();
                }
            } // 关闭 PdfDocument 实例
        } // 关闭 PdfWriter 实例

        // 输出合并成功消息
        Console.WriteLine("PDF files merged successfully!");
    }
}

在此示例中,我们创建一个 PdfMerger 对象并遍历要合并的 PDF 文件列表。我们打开每个源 PDF 文件,将其页面合并到目标 PDF 文档中,然后关闭源 PDF。最后,我们将合并的 PDF 文档保存到新文件中。

结论

iTextSharp 简化了 .NET Core 应用程序中的 PDF 操作,使开发人员能够轻松执行复杂的任务。在本文中,我们重点介绍了合并 PDF 文件,但 iTextSharp 提供了广泛的功能来处理 PDF 生成和修改的各个方面。尝试使用不同的功能来增强您的 PDF 管理能力并简化应用程序的工作流程。

  • 6
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
可以使用以下代码实现在 ASP.NET 使用 iTextSharp 替换 PDF 指定的关键词内容: ```c# using iTextSharp.text.pdf; using iTextSharp.text; protected void ReplacePdfText(string inputPdfPath, string outputPdfPath, string searchText, string replaceText) { PdfReader reader = new PdfReader(inputPdfPath); PdfStamper stamper = new PdfStamper(reader, new FileStream(outputPdfPath, FileMode.Create)); PdfContentByte cb = stamper.GetOverContent(1); BaseFont bf = BaseFont.CreateFont(BaseFont.HELVETICA, BaseFont.CP1252, BaseFont.NOT_EMBEDDED); // 设置字体 cb.SetFontAndSize(bf, 12); // 查找并替换文本 for (int pageIndex = 1; pageIndex <= reader.NumberOfPages; pageIndex++) { var strategy = new SimpleTextExtractionStrategy(); var currentText = PdfTextExtractor.GetTextFromPage(reader, pageIndex, strategy); if (currentText.Contains(searchText)) { var replacedText = currentText.Replace(searchText, replaceText); var rect = strategy.GetLocations(searchText).FirstOrDefault(); if (rect != null) { cb.BeginText(); cb.SetTextMatrix(rect.GetLeft(), rect.GetBottom() - bf.GetAscent(12)); cb.ShowText(replacedText); cb.EndText(); } } } stamper.Close(); reader.Close(); } ``` 其,`inputPdfPath` 是输入 PDF 文件路径,`outputPdfPath` 是输出 PDF 文件路径,`searchText` 是要查找的关键词,`replaceText` 是要替换成的文本。这段代码会遍历 PDF 文件的每一页,查找是否包含指定的关键词,如果包含则进行替换。最后,输出替换后的 PDF 文件到指定路径。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

谢.锋

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值