Apache Tika无法从大型pdf中提取全文内容

时间:2016-11-14 06:06:04

标签: java pdf apache-tika text-extraction

我正在尝试使用apache tika从大型pdf(未扫描/光栅化的pdf)文件中提取文本。

但是在我比较原文(来自pdf)和提取文本后提取文本后,我发现很多文本内容都丢失了。我尝试使用setMaxStringLength(-1)BodyContentHandler(-1)来最大化输出。但仍然无法从pdf文件中提取全文内容。

以下是我试过的两个样本。

样本:1

public class Extract 
{
    public static void main( String[] args ) throws IOException, SAXException, TikaException
    {
        File file = new File("1.pdf");

        //Instantiating Tika facade class
        Tika tika = new Tika();
        tika.setMaxStringLength(-1);
        String filecontent = tika.parseToString(file);
        System.out.println("Extracted Content: " + filecontent);
    }
}

样本:2

public class Extract 
{
    public static void main( String[] args ) throws IOException, SAXException, TikaException
    {
        BodyContentHandler handler = new BodyContentHandler(-1); //-1 to allow parsing for unlimited character
        Metadata metadata = new Metadata();
        FileInputStream inputstream = new FileInputStream(new File("1.pdf"));
        ParseContext pcontext = new ParseContext();

        //parsing the document using PDF parser
        PDFParser pdfparser = new PDFParser(); 
        pdfparser.parse(inputstream, handler, metadata,pcontext);

        //getting the content of the document
        System.out.println("Contents of the PDF :" + handler.toString());

        //getting metadata of the document
        System.out.println("Metadata of the PDF:");
        String[] metadataNames = metadata.names();

        for(String name : metadataNames) {
            System.out.println(name+ " : " + metadata.get(name));
        }
    }
}

我能够看到pdf最后一页的内容。但pdf中缺少随机的文本。

1 个答案:

答案 0 :(得分:0)

这是我身边最愚蠢的错误。我从eclipse控制台获取输出文件,该控制台具有有限的缓冲区空间。当我将输出写入文件时,它似乎是完美的。