• Java 合并、拆分PDF文档


    处理PDF文档时,我们可以通过合并的方式,来任意组几个不同的PDF文件或者通过拆分将一个文件分解成多个子文件,这样的好处是对文档的存储、管理很方便。下面将通过Java程序代码介绍具体的PDF合并、拆分的方法。

    工具

    :2.0.0版本的比之前的1.1.0版本在功能上做了很大提升,支持所有收费版的功能,对于通过Java编程来处理PDF文档非常实用。

    jar文件导入:

    步骤 1在Java程序中新建一个文件夹可命名为Lib。下载安装包后,解压,将解压后的文件夹下的子文件夹lib中的Spire.Pdf.jar和Spire.Common.jar两个文件复制到新建的文件夹下,如下图:

    步骤2建好文件夹后,引用两个文件:选中这两个jar文件,点击鼠标右键,选择“Build Path” – “Add to Build Path”。

    【示例1】合并PDF文档

    import com.spire.pdf.*;
    import java.io.*;
    
    public class Merge2 {
        public static void main(String[] args) throws Exception {
            
            String outputFile = "output/mergeFilesByStream.pdf";
            FileInputStream stream1 = new FileInputStream(new File("sample1.pdf"));
            FileInputStream stream2 = new FileInputStream(new File("sample2.pdf"));
            FileInputStream stream3 = new FileInputStream(new File("sample3.pdf"));
            //加载PDF示例文档
            InputStream[] streams = new FileInputStream[]{stream1, stream2, stream3};
    
            //合并PDF文档
            PdfDocumentBase doc = PdfDocument.mergeFiles(streams);
    
            //保存文档
            doc.save(outputFile);
            doc.close();
        }
    }

    合并前:

    合并后:

    【示例2】拆分PDF文档

    这里分2种情况来进行。

    测试文档:

    1. 按每一页单独拆分

    import com.spire.pdf.*;
    
    public class SplitPDF1 {
        public static void main(String[] args)
        {
        //加载需要拆分的PDF文档
        PdfDocument doc = new PdfDocument();
        doc.loadFromFile("test.pdf");
    
        //调用方法split()将PDF文档按每一页拆分为单独的文档
        doc.split("output/splitDocument-{0}.pdf", 0);
        doc.close();
        }
    }

    拆分结果:

    2. 按指定页数范围拆分

    import com.spire.pdf.*;
    import com.spire.pdf.graphics.PdfMargins;
    
    import java.awt.geom.Point2D;
    
    public class SplitPDF2 {
        public static void main(String[] args)
        {
    
            //加载需要拆分的PDF文档
            PdfDocument doc = new PdfDocument();
            doc.loadFromFile("test.pdf");
    
            //新建第1个PDF文档1
            PdfDocument newpdf1 = new PdfDocument();
            PdfPageBase page;
    
            //将原PDF文档的第1、2页拆分,并保存到newpdf1
            for(int i = 0;i<2;i++)
            {
                page = newpdf1.getPages().add(doc.getPages().get(i).getSize(), new PdfMargins(0));
                doc.getPages().get(i).createTemplate().draw(page, new Point2D.Float(0,0));
            }
            newpdf1.saveToFile("split/result1.pdf");
    
            //新建第2个PDF文档
            PdfDocument newpdf2 = new PdfDocument();
    
            //将原PDF文档的第3、4页拆分,并保存到newpdf2
            for(int i = 2;i<4;i++)
            {
                page = newpdf2.getPages().add(doc.getPages().get(i).getSize(), new PdfMargins(0));
                doc.getPages().get(i).createTemplate().draw(page, new Point2D.Float(0,0));
            }
            newpdf2.saveToFile("split/result2.pdf");
        }
    }

    拆分结果:

    (本文完)

    转载请注明出处!

  • 相关阅读:
    Apache Mahout
    ganglia安装
    编译出错 recompile with -fPIC
    centos6.4 基本安装nagios
    HDU1285 确定比赛名次
    HDU2888 Check Corners(二维RMQ)
    HDU3183 A Magic Lamp
    HDU1711 Number Sequence(KMP模版题)
    HDU3694 Fermat Point in Quadrangle(求四边形费马点)
    POJ2155 Matrix(二维树状数组)
  • 原文地址:https://www.cnblogs.com/Yesi/p/10135734.html
Copyright © 2020-2023  润新知