0

iText-Java を使用して PDF をブックマーク レベルで分割しています。レベル 2 または 3 に存在するブックマークで PDF を分割するための例を誰かが知っているか、持っていますか? 例: 次のレベルのブックマークがあります。


| -息子|- 息子 |-娘|-| -
孫息子
| -|-孫娘


現在、ベースブックマーク(父)を読み取るブックマークを読み取るためのコードを以下に示します。基本的に SimpleBookmark.getBookmark(reader) 行がすべての作業を行いました。

しかし、レベル 2 とレベル 3 のブックマークを読み込んで、それらの内側のレベルのブックマークに存在するコンテンツを分割したいと考えています。

public static void splitPDFByBookmarks(String pdf, String outputFolder){ 
        try
        { 
            PdfReader reader = new PdfReader(pdf); 
            //List of bookmarks: each bookmark is a map with values for title, page, etc 
            List<HashMap> bookmarks = SimpleBookmark.getBookmark(reader); 
            for(int i=0; i<bookmarks.size(); i++){ 
                HashMap bm = bookmarks.get(i); 
                HashMap nextBM = i==bookmarks.size()-1 ? null : bookmarks.get(i+1); 
                //In my case I needed to split the title string 
                String title = ((String)bm.get("Title")).split(" ")[2]; 

                log.debug("Titel: " + title); 
                String startPage = ((String)bm.get("Page")).split(" ")[0]; 
                String startPageNextBM = nextBM==null ? "" + (reader.getNumberOfPages() + 1) : ((String)nextBM.get("Page")).split(" ")[0]; 
                log.debug("Page: " + startPage); 
                log.debug("------------------"); 
                extractBookmarkToPDF(reader, Integer.valueOf(startPage), Integer.valueOf(startPageNextBM), title + ".pdf",outputFolder); 
            } 
        } 
        catch (IOException e) 
        { 
            log.error(e.getMessage()); 
        } 
    } 

    private static void extractBookmarkToPDF(PdfReader reader, int pageFrom, int pageTo, String outputName, String outputFolder){ 
        Document document = new Document(); 
        OutputStream os = null; 

        try{ 
            os = new FileOutputStream(outputFolder + outputName); 

            // Create a writer for the outputstream 
            PdfWriter writer = PdfWriter.getInstance(document, os); 
            document.open(); 
            PdfContentByte cb = writer.getDirectContent(); // Holds the PDF data 
            PdfImportedPage page; 

            while(pageFrom < pageTo) { 
                document.newPage(); 
                page = writer.getImportedPage(reader, pageFrom); 
                cb.addTemplate(page, 0, 0); 
                pageFrom++; 
            } 

            os.flush(); 
            document.close(); 
            os.close(); 
        }catch(Exception ex){ 
            log.error(ex.getMessage()); 
        }finally { 
            if (document.isOpen()) 
                document.close(); 
            try { 
                if (os != null) 
                    os.close(); 
            } catch (IOException ioe) { 
                log.error(ioe.getMessage()); 
            } 
        } 
    } 

あなたの助けに感謝します。前もって感謝します!:)

4

2 に答える 2

0

ArrayList<HashMap>呼び出したときに取得しますSimpleBookmark.getBookmark(reader);(必要な場合はキャストを行います)。その Arraylist を繰り返し処理して、その構造を確認してください。ブックマークに子がある場合 (いわゆる)、同じ構造を持つ別のリストが含まれます。

再帰的な方法が解決策になる可能性があります。

于 2013-04-05T12:38:57.473 に答える