当前位置: 首页 > 知识库问答 >
问题:

从现有的Pdf和(超文本标记语言CSS)创建新的Pdf

林礼骞
2023-03-14

我的用例是我正在动态生成pdf。我也有一个单页的pdf。我想在现有的pdf页面之后/之前连接新生成的PDF。

我已经能够从超文本标记语言生成PDF(这可能导致2-3页)Pdf从超文本标记语言与CSS

我试图查找示例,其中之一是按页面方式连接现有的PDF使用现有的PDF-Concatenate

共有2个答案

孟征
2023-03-14

试试这个例子:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

import com.itextpdf.text.Document;
import com.itextpdf.text.pdf.BaseFont;
import com.itextpdf.text.pdf.PdfContentByte;
import com.itextpdf.text.pdf.PdfImportedPage;
import com.itextpdf.text.pdf.PdfReader;
import com.itextpdf.text.pdf.PdfWriter;

public class UtilPDF {

    public static void main(String[] args) {
    try {
        List<InputStream> pdfs = new ArrayList<InputStream>();

        File pdfDir = new File("C:\\PDF");

        boolean pdfDirectoryExists = true;
        if (!pdfDir.exists()) {
            pdfDirectoryExists = pdfDir.mkdir();
        }

        if (pdfDirectoryExists) {
            pdfs.add(new FileInputStream("C:\\PDF\\Document1.pdf"));
            pdfs.add(new FileInputStream("C:\\PDF\\Document2.pdf"));
            OutputStream output = new FileOutputStream("C:\\Projects\\FinalDocument_1_2.pdf");
            UtilPDF.concatPDFs(pdfs, output, true);
        }

    } catch (Exception e) {
        e.printStackTrace();
    }
}

public static void concatPDFs(List<InputStream> streamOfPDFFiles, OutputStream outputStream, boolean paginate) {
    Document document = new Document();

    try {
        List<InputStream> pdfs = streamOfPDFFiles;
        List<PdfReader> readers = new ArrayList<PdfReader>();
        int totalPages = 0;
        Iterator<InputStream> iteratorPDFs = pdfs.iterator();

        // Create Readers for the pdfs.
        while (iteratorPDFs.hasNext()) {
            InputStream pdf = iteratorPDFs.next();
            PdfReader pdfReader = new PdfReader(pdf);
            readers.add(pdfReader);
            totalPages += pdfReader.getNumberOfPages();
        }

        // Create a writer for the outputstream
        PdfWriter writer = PdfWriter.getInstance(document, outputStream);
        document.open();
        BaseFont bf = BaseFont.createFont(BaseFont.HELVETICA, BaseFont.CP1252, BaseFont.NOT_EMBEDDED);
        PdfContentByte cb = writer.getDirectContent(); // Holds the PDF

        // data
        PdfImportedPage page;
        int currentPageNumber = 0;
        int pageOfCurrentReaderPDF = 0;
        Iterator<PdfReader> iteratorPDFReader = readers.iterator();

        // Loop through the PDF files and add to the output.
        while (iteratorPDFReader.hasNext()) {
            PdfReader pdfReader = iteratorPDFReader.next();

            // Create a new page in the target for each source page.
            while (pageOfCurrentReaderPDF < pdfReader.getNumberOfPages()) {
                document.newPage();
                pageOfCurrentReaderPDF++;
                currentPageNumber++;
                page = writer.getImportedPage(pdfReader, pageOfCurrentReaderPDF);
                cb.addTemplate(page, 0, 0);

                // Code for pagination.
                if (paginate) {
                    cb.beginText();
                    cb.setFontAndSize(bf, 9);
                    cb.showTextAligned(PdfContentByte.ALIGN_CENTER, "" + currentPageNumber + " of " + totalPages,
                            520, 5, 0);
                    cb.endText();
                }
            }
            pageOfCurrentReaderPDF = 0;
        }

        outputStream.flush();
        document.close();
        outputStream.close();

    } catch (Exception e) {
        e.printStackTrace();
    } finally {

        if (document.isOpen())
            document.close();

        try {

            if (outputStream != null)
                outputStream.close();

        } catch (IOException ioe) {
            ioe.printStackTrace();
        }
    }
}
}
越英韶
2023-03-14

这个页面显示了您使用prepend和附加静态PDF以及组合HTML和CSS内容所请求的内容。

http://cloudformatter.com/CSS2Pdf.CustomTipsTricks.InjectPDF

使用说明在这里

http://cloudformatter.com/CSS2Pdf.APIDoc.Usage

 类似资料:
  • 我们有一个基于Java的系统,它从数据库中读取数据,用预设的标记合并单个数据字段,并用将结果转换为。 在格式中,它看起来像这样: 现在我正在寻找一种方法来允许一些字段包含静态超文本标记语言格式的内容。此内容将由我们启用超文本标记语言的编辑器(类似、等的东西)生成或从外部粘贴。 我的计划是遵循这篇JavaWorld文章的配方: < li >使用< code>JTidy将HTML格式的字符串转换为正确

  • 我正在使用ITextRenderer从html生成PDF。然而,我得到以下异常: 你能帮帮我吗? 任何帮助都将不胜感激。 先谢谢你。

  • 我想让我的段落正确地显示出来。 段落示例: Lorem ipsum dolor坐在这里,奉献给我们。拍卖商,拍卖商,拍卖商。整数nec别名urna,一个微调猫。nunc mi quam,简历pharetra quis,dapibus等。二重奏等精英和大人物。莫尔比怀疑一个多洛坐在一起。nunc aliquam, eros molestie eeffitur faucibus, orci diam

  • 我之所以发布这个问题,是因为许多开发人员或多或少地以不同的形式问同一个问题。我会自己回答这个问题(我是iText Group的创始人/首席技术官),这样它就可以成为“维基答案”如果堆栈溢出的“文档”特性仍然存在,那么这将是文档主题的一个很好的候选者。 我正在尝试将以下HTML文件转换为PDF: 在浏览器中,这种超文本标记语言如下所示: HTMLWorker根本不考虑CSS 当我使用时,我需要创建一

  • 因此,这又和我的另一个问题链接到同一个网站,这是另一个定位问题,可能很简单。我有一个容器div,我想在里面放两个div,一个占据容器的三分之一,在右边包含图片,一个包含文本,在左边。然而,由于某种原因,当告诉两个内部div向左浮动时,容器似乎消失了,而当使用inspect元素时,它处于一个我无法解释的奇怪位置。 HTML: CSS: Jscript/jQuery文件只是淡入淡出,但对定位没有影响

  • 本文向大家介绍SGML(标准通用标记语言)和HTML(超文本标记语言),XML(可扩展标记语言)和HTML的之间有什么关系?相关面试题,主要包含被问及SGML(标准通用标记语言)和HTML(超文本标记语言),XML(可扩展标记语言)和HTML的之间有什么关系?时的应答技巧和注意事项,需要的朋友参考一下