如何在PDF文档中搜索字符串

huangapple go评论71阅读模式
英文:

How to search for a string in a pdf document

问题

我有一个包含图像、超链接、文字等内容的PDF文档。

我想要在所有文字中搜索一个字符串,即排除图像和超链接。
如何编写Java代码来实现这一功能。有人可以在这里提供帮助。

英文:

I have a pdf document which contains images, hyperlinks , words and many other things.

I want to search for a sting in all the words, i.e images and hyperlinks are excluded.
How to write a java code with that. Could someone help here.

答案1

得分: 2

你可以使用Apache的PDFbox库(https://pdfbox.apache.org/download.cgi)。
以下是代码示例:

import java.util.Scanner;
import java.io.File;
import java.io.IOException;
import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.text.PDFTextStripper;

public class Main {
    public static void main(String args[]) throws IOException {
        Scanner scan = new Scanner(System.in);
        System.out.println("输入PDF文件的目录:");
        String PDFdir = scan.nextLine();
        System.out.println("输入要查找的短语:");
        String phrase = scan.nextLine();
        File file = new File(PDFdir);
        PDDocument doc = PDDocument.load(file);
        PDFTextStripper findPhrase = new PDFTextStripper();
        String text = findPhrase.getText(doc);
        String PDF_content = text;
        String result = PDF_content.contains(phrase) ? "是" : "否";
        System.out.println(result);
        doc.close();
    }
}

请记得下载PDFbox的JAR文件并将其导入到你的项目中。

输出/结果:

如何在PDF文档中搜索字符串

编辑:

你还可以查找PDF中短语的数量:

if (result.equals("是")) {
    int counter = 0;
    while(PDF_content.contains(phrase)) {
        counter++;
        PDF_content = PDF_content.replaceFirst(phrase, "");
    }
    System.out.println(counter);
}

输出/结果:

如何在PDF文档中搜索字符串

英文:

You can use the PDFbox library of Apache (https://pdfbox.apache.org/download.cgi).
Here is an example of code.

import java.util.Scanner;
import java.io.File;
import java.io.IOException;
import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.text.PDFTextStripper;
public class Main {
    public static void main(String args[]) throws IOException {
        Scanner scan = new Scanner(System.in);
        System.out.println("Type the directory of the PDF File : ");
        String PDFdir = scan.nextLine();
        System.out.println("Input the phrase to find");
        String phrase = scan.nextLine();
        File file = new File(PDFdir);
        PDDocument doc = PDDocument.load(file);
        PDFTextStripper findPhrase = new PDFTextStripper();
        String text = findPhrase.getText(doc);
        String PDF_content = text;
        String result = PDF_content.contains(phrase) ? "Yes" : "No"
        System.out.println(result);
        doc.close();
    }
}

Remember you will have to download PDFbox jar file and import it into your project.

Output/Result :

如何在PDF文档中搜索字符串

Edit:

You can also find the number of phrases in the PDF :

if (result.equals("Yes")) {
    int counter = 0;
        while(PDF_content.contains(phrase)) {
            counter++;
            PDF_content = PDF_content.replaceFirst(phrase, "");
        }
    System.out.println(counter);
}

Output/Result :
如何在PDF文档中搜索字符串

huangapple
  • 本文由 发表于 2020年7月24日 20:04:15
  • 转载请务必保留本文链接:https://go.coder-hub.com/63073189.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定