Net9解决Spire.Pdf替换文字后,文件格式乱掉解决方法

发布于:2024-12-23 ⋅ 阅读:(21) ⋅ 点赞:(0)

官方文档

https://www.e-iceblue.com/Tutorials/Spire.PDF/Program-Guide/Text/Find-and-replace-text-on-PDF-document-in-C.html

C# 在 PDF 中查找替换文本

原文件如下图,替换第一行的新编码,把41230441044替换为41230441000

替换代码如下:

 PdfDocument doc = new PdfDocument();

 //加载PDF文档
 doc.LoadFromFile("Input.pdf");          
 PdfTextReplaceOptions textReplaceOptions = new PdfTextReplaceOptions();
 textReplaceOptions.ReplaceType = PdfTextReplaceOptions.ReplaceActionType.IgnoreCase;
 textReplaceOptions.ReplaceType = PdfTextReplaceOptions.ReplaceActionType.WholeWord;
 textReplaceOptions.ReplaceType = PdfTextReplaceOptions.ReplaceActionType.AutofitWidth;
 PdfPageBase page = doc.Pages[0];
 PdfTextReplacer textReplacer = new PdfTextReplacer(page);
 textReplacer.Options = textReplaceOptions;
 textReplacer.ReplaceAllText("41230441044", "41230441000");
 doc.SaveToFile("ReplaceTextInPage.pdf");
 doc.Dispose();

替换后格式乱了,如下图

解决方法如下,作用PdfTextFinder

参考文档https://www.e-iceblue.com/Tutorials/Spire.PDF/Spire.PDF-Program-Guide/Text/Find-and-Highlight-Selected-Text-in-PDF-in-C-VB.NET.html

C#/VB.NET 在 PDF 文档中查找并突出显示文本

PdfDocument doc = new PdfDocument();

//加载PDF文档
doc.LoadFromFile("Input.pdf");          
PdfPageBase page = doc.Pages[0];
PdfTextFinder finder = new PdfTextFinder(page);
var finds = finder.Find("41230441044");
foreach (var textFragment in finds)
{
    textFragment.ApplyRecoverString("41230441000", Color.White, true);
}
doc.SaveToFile("ReplaceTextInPage.pdf");
doc.Dispose();