Как я могу удалить все изображения / рисунки из файла PDF и оставить текст только на Java? - PullRequest
11 голосов
/ 26 июля 2011

У меня есть файл PDF, который выводится процессором OCR, этот процессор OCR распознает изображение, добавляет текст в pdf, но в конце помещает изображение низкого качества вместо исходного (я понятия не имею, почему кто-тобудет делать это, но они делают).

Итак, я хотел бы получить этот PDF, удалить поток изображений и оставить текст в покое, чтобы я мог получить его и импортировать (используя функцию импорта страниц iText)в PDF я создаю себя с реальным изображением.

И прежде чем кто-то спросит, я уже пытался использовать другой инструмент для извлечения текстовых координат (JPedal), но когда я рисую текст в моем PDF, это не так.находится не в той же позиции, что и оригинал.

Я бы предпочел сделать это на Java, но если другой инструмент может сделать это лучше, просто дайте мне знать.И это может быть только удаление изображения, я могу жить с PDF с чертежами там.

Ответы [ 2 ]

15 голосов
/ 01 августа 2011

Я использовал Apache PDFBox в аналогичной ситуации.

Чтобы быть более конкретным, попробуйте что-то вроде этого:

import org.apache.pdfbox.exceptions.COSVisitorException;
import org.apache.pdfbox.exceptions.CryptographyException;
import org.apache.pdfbox.exceptions.InvalidPasswordException;
import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.pdmodel.PDDocumentCatalog;
import org.apache.pdfbox.pdmodel.PDPage;
import org.apache.pdfbox.pdmodel.PDResources;
import java.io.IOException;

public class Main {
    public static void main(String[] argv) throws COSVisitorException, InvalidPasswordException, CryptographyException, IOException {
        PDDocument document = PDDocument.load("input.pdf");

        if (document.isEncrypted()) {
            document.decrypt("");
        }

        PDDocumentCatalog catalog = document.getDocumentCatalog();
        for (Object pageObj :  catalog.getAllPages()) {
            PDPage page = (PDPage) pageObj;
            PDResources resources = page.findResources();
            resources.getImages().clear();
        }

        document.save("strippedOfImages.pdf");
    }
}

Предполагается удалить все типы изображений (pngJPEG, ...).Это должно работать так:

Пример статьи http://s3.postimage.org/28f6boykk/before.jpg.

5 голосов
/ 29 мая 2013

Вам необходимо проанализировать документ следующим образом:

public static void strip(String pdfFile, String pdfFileOut) throws Exception {

    PDDocument doc = PDDocument.load(pdfFile);

    List pages = doc.getDocumentCatalog().getAllPages();
    for( int i=0; i<pages.size(); i++ ) {
        PDPage page = (PDPage)pages.get( i );

        // added
        COSDictionary newDictionary = new COSDictionary(page.getCOSDictionary());

        PDFStreamParser parser = new PDFStreamParser(page.getContents());
        parser.parse();
        List tokens = parser.getTokens();
        List newTokens = new ArrayList();
        for(int j=0; j<tokens.size(); j++) {
            Object token = tokens.get( j );

            if( token instanceof PDFOperator ) {
                PDFOperator op = (PDFOperator)token;
                if( op.getOperation().equals( "Do") ) {
                    //remove the one argument to this operator
                    // added
                    COSName name = (COSName)newTokens.remove( newTokens.size() -1 );
                    // added
                    deleteObject(newDictionary, name);
                    continue;
                }
            }
            newTokens.add( token );
        }
        PDStream newContents = new PDStream( doc );
        ContentStreamWriter writer = new ContentStreamWriter( newContents.createOutputStream() );
        writer.writeTokens( newTokens );
        newContents.addCompression();

        page.setContents( newContents );

        // added
        PDResources newResources = new PDResources(newDictionary);
        page.setResources(newResources);
    }

    doc.save(pdfFileOut);
    doc.close();
}


// added
public static boolean deleteObject(COSDictionary d, COSName name) {
    for(COSName key : d.keySet()) {
        if( name.equals(key) ) {
            d.removeItem(key);
            return true;
        }
        COSBase object = d.getDictionaryObject(key); 
        if(object instanceof COSDictionary) {
            if( deleteObject((COSDictionary)object, name) ) {
                return true;
            }
        }
    }
    return false;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...