Docx4J从docx文件中获取页眉/页脚元素并进行修改

时间:2013-07-01 14:01:38

标签: java xml docx docx4j

我正在使用Docx4J修改docx模板,并将值放在模板中预定义的占位符中。

到目前为止,我已成功找到并替换了段落和文本,表格,图像等。但我还没有成功找到文档的页眉和/或页脚元素。

我正在使用

WordprocessingMLPackage wordMLPackage =
WordprocessingMLPackage.load(new java.io.File(inputfilepath));
wordMLPackage.getMainDocumentPart(); 

搜索模板中的元素。

3 个答案:

答案 0 :(得分:4)

答案 1 :(得分:2)

这就是我设法替换页脚上的键持有者的方式(在Java中,没有XML)。我遗失的那篇文章是:

JaxbXmlPart part = (JaxbXmlPart) relationshipPart.getPart(r);

来自MailMerger.java提到的来源代码JasonPlutext,在第410行中说明。所以,谢谢JasonPlutext

public static void replaceElementFromFooter(WordprocessingMLPackage template, String nameplace, String placeholder, String newValue) throws Docx4JException {
    List<Object> result = new ArrayList<Object>();

    RelationshipsPart relationshipPart = template.getMainDocumentPart().getRelationshipsPart();

    List<Relationship> relationships = relationshipPart.getRelationships().getRelationship()

    for (Relationship r : relationships) {

        if (r.getType().equals(nameplace)) {

            JaxbXmlPart part = (JaxbXmlPart) relationshipPart.getPart(r);

            List<Object> texts = getAllElementsFromObject(part.getContents(), Text.class);

            replaceTextElement(texts, placeholder, newValue);
        }

    }

    return result;
}

private static List<Object> getAllElementsFromObject(Object obj, Class<?> toSearch) {
    List<Object> result = new ArrayList<Object>();

    if (obj instanceof JAXBElement) {
        obj = ((JAXBElement<?>) obj).getValue();
    }

    if (obj.getClass().equals(toSearch)) {
        result.add(obj);
    } else if (obj instanceof ContentAccessor) {
        List<?> children = ((ContentAccessor) obj).getContent();
        for (Object child : children) {
            result.addAll(getAllElementFromObject(child, toSearch));
        }
    }
    return result;
}

private static void replaceTextElement(List<Object> texts, String placeholder, String newValue) {
    for (Object element : texts) {
        Text textElement = (Text) element;

        if (textElement.getValue().contains(placeholder)) {
            String replacedValue = textElement.getValue().replaceAll(placeholder, newValue);
            textElement.setValue(replacedValue);
        }

    }
}

答案 2 :(得分:0)

如果您在XML中搜索和替换,则可以使用:

String xpath = "//w:r[w:t[contains(text(), 'placeholder')]]";
List<Object> list = wordMLPackage.getHeaderFooterPolicy().getDefaultHeader().getJAXBNodesViaXPath(xpath, false);
list.addAll(wordMLPackage.getHeaderFooterPolicy().getDefaultFooter().getJAXBNodesViaXPath(xpath, false));

该列表包含占位符所在的所有节点。你可以用我在这里解释的方法得到占位符的类型(文本,图片......)(它是用于文本但很容易适应): replace_placeholder