JAVA将一个pdf按页码拆分成多个pdf

 

 

引入maven

复制代码
   <dependency>
            <groupId>com.itextpdf</groupId>
            <artifactId>itextpdf</artifactId>
            <version>5.5.13</version>
        </dependency>
        <dependency>
            <groupId>org.bouncycastle</groupId>
            <artifactId>bcprov-jdk15on</artifactId>
            <version>1.47</version>
        </dependency>
        <dependency>
            <groupId>org.bouncycastle</groupId>
            <artifactId>bcmail-jdk15on</artifactId>
            <version>1.47</version>
        </dependency>
复制代码

 

 

复制代码
public static void main(String[] args) throws Exception {
        // 根据页码拆分pdf,有多少页就拆成多少张pdf
        File file = new File("pdf文件绝对路径");
        PdfReader pdfReader = new PdfReader(new FileInputStream(file));
        int pages = pdfReader.getNumberOfPages();
        // 设置日期格式
        SimpleDateFormat df = new SimpleDateFormat("yyyyMMddHHmmss");
        for (int i = 1; i <= pages; i++) {
            PdfReader reader = new PdfReader("pdf文件绝对路径");
            Document doc = new Document();
            // 每个pdf命名规则:时间戳(2019109143408)+"-"+顺序编号(i)
            String pdfName =  "D:/test/" + df.format(new Date()) + "-" + i + ".pdf";
            PdfWriter writer = PdfWriter.getInstance(doc, new FileOutputStream(pdfName));
            doc.open();
            PdfContentByte cb = writer.getDirectContent();
            doc.newPage();
            cb.addTemplate(writer.getImportedPage(reader, i), 0, 0);
            doc.close();
            writer.close();
            reader.close();
        }
    }
复制代码

 

posted @   yvioo  阅读(568)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
历史上的今天:
2019-03-18 微信公众号开发——处理微信浏览器页面样式缓存问题
2019-03-18 Centos使用natapp教程
点击右上角即可分享
微信分享提示