java - 将文档转换为 pdf 时如何将 pTab 元素添加到 docx4j

标签 java pdf document docx4j

我在使用Java中的docx4j库将文档转换为pdf时遇到一些错误。遗憾的是,我的错误是这样的

NOT IMPLEMENTED support for w:pict without v:imagedata

它显示在转换后的 pdf 上,而不是在我的 java 终端中显示错误。

我浏览了一些文章和问题,因此找到了这个converting docx to pdf 。但是,我不确定如何在我的代码中使用它或转换它。这是我的代码:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.List;
import java.util.Map;

import org.docx4j.convert.out.pdf.viaXSLFO.PdfSettings;
import org.docx4j.fonts.PhysicalFont;
import org.docx4j.fonts.PhysicalFonts;
import org.docx4j.model.structure.SectionWrapper;
import org.docx4j.openpackaging.packages.WordprocessingMLPackage;

public class docTopdf {
    public static void main(String[] args) {
        try {
            InputStream is = new FileInputStream(
                    new File(
                            "test.docx"));
            WordprocessingMLPackage wordMLPackage = WordprocessingMLPackage
                    .load(is);

            List<SectionWrapper> sections = wordMLPackage.getDocumentModel().getSections();
            for (int i = 0; i < sections.size(); i++) {

                wordMLPackage.getDocumentModel().getSections().get(i)
                        .getPageDimensions();
            }
            PhysicalFonts.discoverPhysicalFonts();
            @Deprecated
            Map<String, PhysicalFont> physicalFonts = PhysicalFonts.getPhysicalFonts();

            // 2) Prepare Pdf settings
            @Deprecated
                    PdfSettings pdfSettings = new PdfSettings();

            // 3) Convert WordprocessingMLPackage to Pdf
            @Deprecated
            org.docx4j.convert.out.pdf.PdfConversion conversion = new org.docx4j.convert.out.pdf.viaXSLFO.Conversion(
                    wordMLPackage);
            @Deprecated
            OutputStream out = new FileOutputStream(
                    new File(
                            "test.pdf"));
            conversion.output(out, pdfSettings);
        } catch (Throwable e) {

            e.printStackTrace();
        }
    }
}

还有我的pom.xml

   <dependency>
            <groupId>org.docx4j</groupId>
            <artifactId>docx4j</artifactId>
            <version>3.2.1</version>
        </dependency>

任何帮助将不胜感激,因为我对这种转换很菜鸟。提前致谢

最佳答案

通过 XSL FO 创建 PDF 不支持没有 v:imagedata 的 w:pict(即不是简单图像的图形)。

虽然您可以通过适当配置日志记录来抑制该消息,但您的 PDF 输出将会有损。

您的选择是更正输入的 docx(即使用图像而不是您当前拥有的任何图像),或使用具有适当支持的 PDF 转换器。对于一种选项,请参阅https://www.docx4java.org/blog/2020/03/documents4j-for-pdf-output/

关于java - 将文档转换为 pdf 时如何将 pTab 元素添加到 docx4j,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60809721/

相关文章:

wpf - 通过分页器保存和打印 XPSDocument(似乎)会导致内容光栅化

linux - 如何在Linux操作系统中将任何文档格式转换为jpg文件

java - 对等方的证书签名无效。错误代码: SEC_ERROR_BAD_SIGNATURE error with Selenium GeckoDriver and Firefox through Java

java - 可以使用接口(interface)来实现抽象吗

r - 使用 knitr 强制执行 PDF 包小插图

jquery - POST XML 到服务器,接收 PDF

LaTeX 书籍类 : Twosided document with wrong margins

java - 如何使用 Spring Properties 配置 Velocity Escape Tool?

java - 我的表中不存在列 @Entity @Column

amazon-web-services - 为什么我使用预先签名的 AWS S3 url 上传的 pdf 没有正确的内容类型?