java - iText PdfTextExtractor getTextFromPage 异常 "Error reading string at file pointer"

标签 java jakarta-ee itext

我正在使用 iText PdfTextExtractor 从 PdfReader 中提取文本,其中 PdfReader 是从字节数组创建的,

    byte[] pdfbytes = outputStream.toByteArray();

    PdfReader reader = new PdfReader(pdfbytes);

    int pagenumber = reader.getNumberOfPages();
    PdfTextExtractor extractor = new PdfTextExtractor(reader);

    for(int i = 1; i<= pagenumber; i++) {
        System.out.println("============PAGE NUMBER " + i + "=============" );
        String line = extractor.getTextFromPage(i);
        System.out.println(line);
    }

第一个测试pdf来自:http://www.gnostice.com/downloads/Gnostice_PathQuest.pdf 我可以打印第一页,但在第二页出现以下异常

异常(exception):

Exception in thread "main" ExceptionConverter: java.io.IOException: Error reading string at file pointer 238291
at com.lowagie.text.pdf.PRTokeniser.throwError(Unknown Source)
at com.lowagie.text.pdf.PRTokeniser.nextToken(Unknown Source)
at com.lowagie.text.pdf.PdfContentParser.nextValidToken(Unknown Source)
at com.lowagie.text.pdf.PdfContentParser.readPRObject(Unknown Source)
at com.lowagie.text.pdf.PdfContentParser.parse(Unknown Source)
at com.lowagie.text.pdf.parser.PdfContentStreamProcessor.processContent(Unknown Source)
at com.lowagie.text.pdf.parser.PdfTextExtractor.getTextFromPage(Unknown Source)
at org.xxx.services.pdfparser.xxxExtensionPdfParser.main(xxxExtensionPdfParser.java:114)

其中 xxxExtensionPdfParser.java:114 是 String line = extractor.getTextFromPage(i);

但在第二次测试时 http://www.irs.gov/pub/irs-pdf/fw4.pdf ,我可以毫无异常(exception)地获取文本内容。所以我认为一定是第一个pdf的格式问题导致了异常。

所以我的问题是,这个格式问题是什么,有什么办法可以避免它吗?谢谢。

最佳答案

我遇到了同样的错误,经过一些调查,我的 pdf 文档的问题似乎是它们包含“页眉”或“页脚”,而不是您链接的 IRS 文档。我索引了一份 900 页的 pdf 文档,其中大约 70 页无法提取。显然,所有这些页面都有页脚版权信息。有什么想法可以解决这个问题吗?

------编辑---------- 我应用了以下方法从上述 pdf 中获取文本。希望这也适合您。

<小时/>
PdfReader pdfReader = new PdfReader(file);
PdfReaderContentParser parser = new PdfReaderContentParser(pdfReader);

strategy = parser.processContent(currentPage, new SimpleTextExtractionStrategy());              
content = strategy.getResultantText();

关于java - iText PdfTextExtractor getTextFromPage 异常 "Error reading string at file pointer",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8588485/

相关文章:

java - 设计 Web 服务的最佳方法,必须将请求中的数据存储在列表或类似结构中

javascript - 模拟Javascript函数中的href点击?

c# - 如何在 iTextSharp 中使用 PdfWriter 而不是 PdfCopy 复制表单域

java - 如何让 Selenium 在 <ul> 下拉列表中选择值?

java - 如何使用 Itext 用正确的编码替换 pdf 中的文本

Java EE WebApp ServiceLoader 将外部 jar 作为插件加载

css - PDF - @Page CSS - 在所有页面中添加页边距

android - 使用 itext 在 PdfPtable 中为 PdfPcell 添加虚线边框?

java - 带有 AMQP 的 Azure 服务总线 - 如何指定 session ID

java - 文件分隔符 Java。它是在编译时还是在运行时确定的?