Java 在PDF中替换文字(详解)

news2024/9/20 22:47:37

目录

使用工具

Java在PDF中替换特定文字的所有实例

Java在PDF中替换特定文字的第一个实例

Java在PDF中使用正则表达式替换特定文字

其他替换条件设置

可能出现的问题及解决方案


PDF文档中的信息随时间的推移可能会发生变化,比如产品价格、联系方式等。为了确保PDF文档保持最新,我们需要对这些信息进行更新。通过编程方式替换PDF中的相应文字,可以实现批量化处理,大大提高工作效率。这篇博客将探讨几种使用Java在PDF中替换文字的不同方式,以及可能出现的问题和解决方案。

使用工具

在PDF中替换文字,可以使用Spire.PDF for Java库。

Spire.PDF for Java是一款专门为Java开发人员设计的PDF文档处理库。它支持在Java应用程序中创建、读取、编辑、转换和打印PDF文档。你可以使用以下代码来从Maven仓库安装它:

<repositories>
    <repository>
        <id>com.e-iceblue</id>
        <name>e-iceblue</name>
        <url>https://repo.e-iceblue.cn/repository/maven-public/</url>
    </repository>
</repositories>
<dependencies>
    <dependency>
        <groupId>e-iceblue</groupId>
        <artifactId>spire.pdf</artifactId>
        <version>10.6.2</version>
    </dependency>
</dependencies>

Java在PDF中替换特定文字的所有实例

Spire.PDF for Java提供了PdfTextReplacer.replaceAllText()方法,支持替换PDF页面中特定文字的所有实例。具体步骤如下:

  • 创建PdfDocument类的实例。
  • 使用PdfDocument.loadFromFile()方法加载PDF文档。
  • 遍历PDF文档中的页面。
  • 为每个页面创建一个PdfTextReplacer实例,并将当前页面对象作为参数传入该类的构造函数。
  • 使用PdfTextReplacer.replaceAllText()方法将页面上特定文字的所有实例替换为新文字。
  • 使用PdfDocument.saveToFile() 方法保存结果文档。
import com.spire.pdf.PdfDocument;
import com.spire.pdf.PdfPageBase;
import com.spire.pdf.texts.PdfTextReplacer;

public class ReplaceAllFoundText {
    public static void main(String[] args) {
        // 创建PdfDocument类的实例
        PdfDocument pdf = new PdfDocument();
        // 加载PDF文件
        pdf.loadFromFile("什么是Python.pdf");

        // 遍历PDF文件的页面
        for (PdfPageBase page : (Iterable<? extends PdfPageBase>) pdf.getPages()) {
            // 创建PdfTextReplacer类的实例,并将当前页面对象作为参数传递至该类的构造函数
            PdfTextReplacer textReplacer =  new PdfTextReplacer(page);
            // 将当前页面上的特定文本的所有实例替换为新文本
            textReplacer.replaceAllText("Python", "Golang");
        }

        // 将结果文件保存为一个新的PDF
        pdf.saveToFile("替换所有实例.pdf");
        pdf.close();
    }
}

Python 替换PDF中特定文本的所有实例

Java在PDF中替换特定文字的第一个实例

要替换PDF页面中特定文字的第一个实例,可以使用PdfTextReplacer.replaceText() 方法。具体步骤如下:

  • 创建PdfDocument类的实例。
  • 使用PdfDocument.loadFromFile()方法加载PDF文档。
  • 遍历PDF文档中的页面。
  • 为每个页面创建一个PdfTextReplacer实例,并将当前页面对象作为参数传入该类的构造函数。
  • 使用PdfTextReplacer.replaceText() 方法将页面上特定文字的第一个实例替换为新文字。
  • 使用PdfDocument.saveToFile() 方法保存结果文档。
import com.spire.pdf.PdfDocument;
import com.spire.pdf.PdfPageBase;
import com.spire.pdf.texts.PdfTextReplacer;

public class ReplaceFirstFoundText {
    public static void main(String[] args) {
        // 创建PdfDocument类的实例
        PdfDocument pdf = new PdfDocument();
        // 加载PDF文件
        pdf.loadFromFile("什么是Python.pdf");

        // 遍历PDF文件的页面
        for (PdfPageBase page : (Iterable<? extends PdfPageBase>) pdf.getPages()) {
            // 创建PdfTextReplacer类的实例,并将当前页面对象作为参数传递至该类的构造函数
            PdfTextReplacer textReplacer =  new PdfTextReplacer(page);
            // 将当前页面上的特定文本的第一个实例替换为新文本
            textReplacer.replaceText("Python", "Golang");
        }

        // 将结果文件保存为一个新的PDF
        pdf.saveToFile("替换第一个实例.pdf");
        pdf.close();
    }
}

Java在PDF中使用正则表达式替换特定文字

Spire.PDF for Java提供了PdfTextReplaceOptions类,用于指定文字替换模式。你可以通过该类的setReplaceType() 方法指定文本替换模式为使用正则表达式替换。然后使用 PdfTextReplacer.setOptions() 方法应用该文字替换模式。具体步骤如下:

  • 创建PdfDocument类的实例。
  • 使用PdfDocument.loadFromFile()方法加载PDF文档。
  • 创建PdfTextReplaceOptions类的实例,并使用PdfTextReplaceOptions.setReplaceType() 方法指定文本替换模式为使用正则表达式替换。
  • 遍历PDF文档中的页面。
  • 为每个页面创建一个PdfTextReplacer实例,并将当前页面对象作为参数传入该类的构造函数。
  • 使用 PdfTextReplacer.setOptions() 方法应用正则表达式替换模式。
  • 将正则表达式和新文本作为参数传入PdfTextReplacer.replaceAllText()方法来将页面上正则表达式匹配到的文本替换为新文本。
  • 使用PdfDocument.saveToFile() 方法保存结果文档。
import com.spire.pdf.PdfDocument;
import com.spire.pdf.PdfPageBase;
import com.spire.pdf.texts.PdfTextReplaceOptions;
import com.spire.pdf.texts.PdfTextReplacer;
import com.spire.pdf.texts.ReplaceActionType;

import java.util.EnumSet;

public class ReplaceTextWithRegex {
    public static void main(String[] args) {
        // 创建PdfDocument类的实例
        PdfDocument pdf = new PdfDocument();
        // 加载PDF文件
        pdf.loadFromFile("模板.pdf");

        // 创建PdfTextReplaceOptions类的实例,并指定文本替换模式为使用正则表达式替换
        PdfTextReplaceOptions replaceOptions = new PdfTextReplaceOptions();
        replaceOptions.setReplaceType(EnumSet.of(ReplaceActionType.Regex));

        // 遍历PDF文件的页面
        for (PdfPageBase page : (Iterable<? extends PdfPageBase>) pdf.getPages()) {
            // 创建PdfTextReplacer类的实例,并将当前页面对象作为参数传递至该类的构造函数
            PdfTextReplacer textReplacer =  new PdfTextReplacer(page);
            // 应用正则表达式替换模式
            textReplacer.setOptions(replaceOptions);

            // 设置正则表达式来匹配以 “#” 开头的文本
            String regularExpression = "\\#\\w+\\b";
            // 将页面上正则表达式匹配到的文本替换为新文本
            textReplacer.replaceAllText(regularExpression, "显示器");
        }

        // 将结果文件保存为一个新的PDF
        pdf.saveToFile("正则表达式替换.pdf");
        pdf.close();
    }
}

Python 使用正则表达式替换PDF中的文本

其他替换条件设置

Spire.PDF for Java还支持设置其他替换条件,如不区分大小写全词匹配。具体代码如下:

import com.spire.pdf.PdfDocument;
import com.spire.pdf.PdfPageBase;
import com.spire.pdf.texts.PdfTextReplaceOptions;
import com.spire.pdf.texts.PdfTextReplacer;
import com.spire.pdf.texts.ReplaceActionType;

import java.util.EnumSet;

public class OtherReplacementSettings {
    public static void main(String[] args) {
        // 创建PdfDocument类的实例
        PdfDocument pdf = new PdfDocument();
        // 加载PDF文件
        pdf.loadFromFile("什么是Python.pdf");

        // 创建PdfTextReplaceOptions类的实例,并指定文本替换模式为不区分大小写或全词匹配
        PdfTextReplaceOptions replaceOptions = new PdfTextReplaceOptions();
        replaceOptions.setReplaceType(EnumSet.of(ReplaceActionType.IgnoreCase));
        replaceOptions.setReplaceType(EnumSet.of(ReplaceActionType.WholeWord));

        // 遍历PDF文件的页面
        for (PdfPageBase page : (Iterable<? extends PdfPageBase>) pdf.getPages()) {
            // 创建PdfTextReplacer类的实例,并将当前页面对象作为参数传递至该类的构造函数
            PdfTextReplacer textReplacer =  new PdfTextReplacer(page);
            // 应用文本替换模式
            textReplacer.setOptions(replaceOptions);

            // 将页面上特定文本替换为新文本
            textReplacer.replaceAllText("Python", "Golang");
        }

        // 将结果文件保存为一个新的PDF
        pdf.saveToFile("其他替换条件.pdf");
        pdf.close();
    }
}

可能出现的问题及解决方案

当使用 PdfTextReplacer类的方法进行文本替换时,默认情况下,替换后的新文本会使用PDF文档中原始文本的字体来绘制。如果原始文本所使用的字体不支持新文本所使用的语言,那么新文本就无法正确地显示出来。这种情况通常会出现在需要替换不同语言的文本时。比如,原文是英文,需要替换为中文,但是英文字体可能不支持显示中文字符。为解决这个问题,可以考虑以下2种方法:

  1. 文档使用能够兼容原文本和新文本的语言的字体。
  2. 采用另一种方法替换文本:通过在原始文本上绘制矩形覆盖它,然后在矩形内绘制新文本,注意这种方式不能保留原始文本的样式,需要自己设置新文本的样式,效果没有使用PdfTextReplacer方法好。具体代码如下:
import com.spire.pdf.*;
import com.spire.pdf.graphics.*;
import com.spire.pdf.texts.*;

import java.awt.*;
import java.awt.geom.Rectangle2D;
import java.util.List;

public class ReplaceTextByDrawingRectangle {
    public static void main(String[] args) {
        // 创建PdfDocument类的实例
        PdfDocument pdf = new PdfDocument();
        // 加载PDF文件
        pdf.loadFromFile("Adobe Acrobat.pdf");

        // 定义字体(如果字体已安装在系统中)
        PdfTrueTypeFont font = new PdfTrueTypeFont(new Font("宋体", Font.PLAIN, 11));
        // 如果字体未安装在系统中,使用以下代码
        // PdfTrueTypeFont font = new PdfTrueTypeFont("字体文件.ttf", 11);

        PdfStringFormat format = new PdfStringFormat();
        format.setLineLimit(false);

        List<PdfTextFragment> results = null;
        // 遍历PDF文件的页面
        for (PdfPageBase page : (Iterable<? extends PdfPageBase>) pdf.getPages()) {
            // 创建 PdfTextFinder 实例
            PdfTextFinder finder = new PdfTextFinder(page);
            // 查找特定文本
            results =  finder.find("Adobe Acrobat");
            // 遍历找到的所有实例
            for (PdfTextFragment text : results) {
                // 获取文本所在的矩形区域
                 Rectangle2D rect = text.getBounds()[0];
                // 在该区域画一个新的矩形覆盖原来的文本
                page.getCanvas().drawRectangle(PdfBrushes.getWhite(), rect);
                // 在新的矩形中绘制新文本
                page.getCanvas().drawString("PDF编辑器", font, PdfBrushes.getDarkBlue(), rect, format);
            }
        }

        // 将结果文件保存为一个新的PDF
        pdf.saveToFile("覆盖文本.pdf");
        pdf.close();
    }
}

以上就是使用Java在PDF中替换文字的全部内容。本文完结。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1935951.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

迭代学习笔记

一、迭代学习定义和分类 1、直观理解 迭代学习一般应用于重复性的场景。比如控制一个单自由度的小车以特定的速度曲线移动到指定位置&#xff0c;整个时间是10s&#xff0c;控制频率是0.01&#xff0c;那么整个控制序列就会有1000个点。这1000个点在10s内依次发出&#xff0c…

网络编程-TCP 协议的三次握手和四次挥手做了什么

TCP 协议概述 1. TCP 协议简介 TCP&#xff08;Transmission Control Protocol&#xff0c;传输控制协议&#xff09;是一种面向连接的、可靠的、基于字节流的传输层通信协议。 TCP 协议提供可靠的通信服务&#xff0c;通过校验和、序列号、确认应答、重传等机制保证数据传输…

Pytorch学习笔记day4——训练mnist数据集和初步研读

该来的还是来了hhhhhhhhhh&#xff0c;基本上机器学习的初学者都躲不开这个例子。开源&#xff0c;数据质量高&#xff0c;数据尺寸整齐&#xff0c;问题简单&#xff0c;实在太适合初学者食用了。 今天把代码跑通&#xff0c;趁着周末好好的琢磨一下里面的各种细节。 代码实…

C++内存管理(区别C语言)深度对比

欢迎来到我的Blog&#xff0c;点击关注哦&#x1f495; 前言 前面已经介绍了类和对象&#xff0c;对C面向对象编程已经有了全面认识&#xff0c;接下来要学习对语言学习比较重要的是对内存的管理。 一、内存的分区 代码区&#xff1a;存放程序的机器指令&#xff0c;通常是可…

js实现数组的下标为n的对象后面新增一条对象

前言&#xff1a; js实现数组的下标为n的对象后面新增一条对象 实现方法&#xff1a; arr.splice(1, 0, obj); splice 参数1: 数组里面的第几个元素&#xff0c;你希望在第几个对象后面新增参数2: 0 表示不删除任何元素参数3: 插入的新对象 let arr [{},{},{},{}] let obj…

vue使用echarts开发大屏可视化(附echarts案例资源)

近年来&#xff0c;可视化在前端领域是越来越多。最近投入的一个项目就是关于大屏可视化&#xff0c;基本就是用到了echarts&#xff0c;所以项目结束后&#xff0c;我也来总结一下如何在Vue中去引入echarts并使用。 文章目录 一、echarts案例网站可视化社区(https://www.makea…

Zoho Mail企业邮箱好用吗?

企业在选择企业邮箱时需要考虑三大因素&#xff0c;一是安全隐私&#xff0c;二是功能易用&#xff0c;三是产品价格。作为国际排行前五的企业邮箱&#xff0c;Zoho邮箱好用吗&#xff1f;本文将为您详细介绍Zoho邮箱的功能、安全性和产品价格。 一、安全隐私 1、数据加密与安…

MySQL----初始数据类型

前言 一、tinyint 范围&#xff1a;-128-----127 在MySQL中&#xff0c;整型可以指定是有符号的和无符号的&#xff0c;默认是有符号的。可以通过UNSIGNED来说明某个字段是无符号的。如果我们向mysqlt特定的类型中插入不合法的数据&#xff0c;Mysq一般会直接拦截&#xff0c…

【HarmonyOS学习】定位相关知识(Locationkit)

简介 LocationKit提供了定位服务、地理围栏、地理编码、逆地理编码和国家码等功能。 可以实现点击获取用户位置信息、持续获取位置信息和区域进出监控等多项功能。 需要注意&#xff0c;需要确定用户已经开启定位信息&#xff0c;一下的代码没有做这一步的操作&#xff0c;默…

p17面试题

品茗面试题 1.交换两个int变量的值&#xff0c;不能使用第三个变量&#xff0c;即a3,b5,交换后&#xff0c;a5,b3&#xff1b; #include<stdio.h> //int main(){ // //打印函数&#xff0c;引用头文件.stdio.h // printf("hello world\n");//打印函数 …

C++STL详解(二)——string类的模拟实现

首先&#xff0c;我们为了防止命名冲突&#xff0c;我们需要在自己的命名空间内实现string类。 一.string类基本结构 string类的基本结构和顺序表是相似的&#xff0c;结构如下&#xff1a; //.h namespace kuzi {class string{private:char* _str;//字符串size_t _size;//长…

算法基础之回溯法

本文将详细介绍回溯法的基本原理和适用条件&#xff0c;并通过经典例题辅助读者理解回溯法的思想、掌握回溯法的使用。本文给出的例题包括&#xff1a;N皇后问题、子集和问题。 算法原理 在问题的解空间树中&#xff0c;回溯法按照深度优先的搜索策略&#xff0c;从根结点出发…

LDR6020:重塑iPad一体式有线键盘体验的创新力量

在移动办公与娱乐日益融合的时代&#xff0c;iPad凭借其强大的性能和便携性&#xff0c;成为了众多用户不可或缺的生产力工具。然而&#xff0c;为了进一步提升iPad的使用体验&#xff0c;一款高效、便捷的键盘成为了不可或缺的配件。今天&#xff0c;我们要介绍的&#xff0c;…

TYPE-C接口PD取电快充协议芯片ECP5701:支持PD 2.0和PD 3.0(5V,9V,12V,15V,20V)

随着智能设备的普及&#xff0c;快充技术成为了越来越多用户的刚需。而TYPE-C接口作为新一代的USB接口&#xff0c;具有正反插、传输速度快、充电体验好等优点&#xff0c;已经成为了快充技术的主要接口形式。而TYPE-C接口的PD&#xff08;Power Delivery&#xff09;取电快充协…

【数据结构】线性结构——数组、链表、栈和队列

目录 前言 一、数组&#xff08;Array&#xff09; 1.1优点 1.2缺点 1.3适用场景 二、链表&#xff08;Linked List&#xff09; 2.1优点 2.2缺点 2.3适用场景 三、栈&#xff08;Stack&#xff09; 3.1优点 3.2缺点 3.3适用场景 四、队列&#xff08;Queue&#xff09; 4.1优点…

【python】Python高阶函数--reduce函数的高阶用法解析与应用实战

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

Redis常用的5大数据类型

Reids字符串&#xff08;String&#xff09; 设置相同的key&#xff0c;之前内容会覆盖掉 Redis列表&#xff08;List&#xff09; 常用命令 从左往右放值 数据结构 Redis集合&#xff08;set&#xff09; sadd<key><value1><value2>...... 数据结构 Set数据…

前端组件化开发:以Vue自定义底部操作栏组件为例

摘要 随着前端技术的不断演进&#xff0c;组件化开发逐渐成为提升前端开发效率和代码可维护性的关键手段。本文将通过介绍一款Vue自定义的底部操作栏组件&#xff0c;探讨前端组件化开发的重要性、实践过程及其带来的优势。 一、引言 随着Web应用的日益复杂&#xff0c;传统的…

「豆包Marscode体验官」 | 云端 IDE 启动 Rust 体验

theme: cyanosis 我正在参加「豆包MarsCode初体验」征文活动 MarsCode 可以看作一个运行在服务端的远程 VSCode开发环境。 对于我这种想要学习体验某些语言&#xff0c;但不想在电脑里装环境的人来说非常友好。本文就来介绍一下在 MarsCode里&#xff0c;我的体验 rust 开发体验…

Games101学习笔记 Lecture22 Animation(cont.)

Lecture22 Animation(cont. 一、单个粒子模拟Ordinary Differential Equation ODE 常微分方程ODE求解方法——欧拉方法解决不稳定中点法改进欧拉方法自适应步长隐式欧拉方法 二、流体模拟基于位置的方法物质点方法 一、单个粒子模拟 想模拟粒子在场中的运动 Ordinary Differe…