Docx4j版本2.8.1.3
docx是一个非常简单的文档,只有一些文本,但它似乎不适用于任何docx。
在docx4j论坛上查看源/异常可能更容易。 http://www.docx4java.org/forums/pdf-output-f27/docx4j-to-pdf-fop-issues-cannot-perform-the-transformation-t1652.html
如果在一个地方接听,我会用答案更新两个
这是例外
fourseasons.general.conversionservice.converter.AbstractConverter FOP issues
org.docx4j.openpackaging.exceptions.Docx4JException: FOP issues
Caused by: org.docx4j.openpackaging.exceptions.Docx4JException: Cannot perform the transformation
at org.docx4j.XmlUtils.transform(XmlUtils.java:911)
at org.docx4j.XmlUtils.transform(XmlUtils.java:802)
at org.docx4j.convert.out.pdf.viaXSLFO.Conversion.output(Conversion.java:349)
... 230 more
Caused by: javax.xml.transform.TransformerException: java.lang.NullPointerException
at org.apache.xalan.transformer.TransformerImpl.executeChildTemplates(TransformerImpl.java:2405)
at org.apache.xalan.templates.ElemLiteralResult.execute(ElemLiteralResult.java:1376)
at org.apache.xalan.templates.ElemApplyTemplates.transformSelectedNodes(ElemApplyTemplates.java:395)
at org.apache.xalan.templates.ElemApplyTemplates.execute(ElemApplyTemplates.java:178)
at org.apache.xalan.transformer.TransformerImpl.executeChildTemplates(TransformerImpl.java:2400)
at org.apache.xalan.transformer.TransformerImpl.applyTemplateToNode(TransformerImpl.java:2270)
at org.apache.xalan.transformer.TransformerImpl.transformNode(TransformerImpl.java:1356)
at org.apache.xalan.transformer.TransformerImpl.transform(TransformerImpl.java:709)
at org.apache.xalan.transformer.TransformerImpl.transform(TransformerImpl.java:1273)
at org.apache.xalan.transformer.TransformerImpl.transform(TransformerImpl.java:1251)
at org.docx4j.XmlUtils.transform(XmlUtils.java:909)
... 232 more
Caused by: java.lang.NullPointerException
at org.apache.xalan.templates.ElemVariable.getValue(ElemVariable.java:282)
at org.apache.xalan.templates.ElemVariable.execute(ElemVariable.java:248)
at org.apache.xalan.templates.ElemApplyTemplates.transformSelectedNodes(ElemApplyTemplates.java:395)
at org.apache.xalan.templates.ElemApplyTemplates.execute(ElemApplyTemplates.java:178)
at org.apache.xalan.transformer.TransformerImpl.executeChildTemplates(TransformerImpl.java:2400)
创建字节的代码:
Mapper fontMapper = new IdentityPlusMapper();
wordmlPackage.setFontMapper(fontMapper);
org.docx4j.convert.out.pdf.viaXSLFO.Conversion c = new org.docx4j.convert.out.pdf.viaXSLFO.Conversion(
wordmlPackage);
ByteArrayOutputStream os = new ByteArrayOutputStream();
c.output(os, new PdfSettings());
os.close();
binarypdf = os.toByteArray();
答案 0 :(得分:0)
我不知道导致此问题的原因,但我将其缩小为无法处理的格式。我只是一个接一个地从错误文档的副本开始删除页面。然后当我终于到达doc将转换到PDF的位置时,我知道我找到了有问题的页面。
从那里开始只是将页面的内容从Word中删除,将其粘贴到另一个应用程序(在我的情况下为Pages)然后返回到Word并重新编写该页面的格式。粘贴前面的页面然后瞧。虫子不见了。
答案 1 :(得分:0)
我有同样的问题。按Ctrl + A突出显示所有页面元素,找到无法转换的元素。