We're sorry Aspose doesn't work properply without JavaScript enabled.

Free Support Forum - aspose.com

Aspose.word:两个word合并后,已经在第二个word里设置的页码会丢失

word合并.zip (153.6 KB)
第二个word里包含了使用aspose生成的目录和页码,再用第一个word与第二个word进行合并,页码就不见了,请问该如何解决

@liujing111, 你是 .NET 还是 Java? 你能展示你用于文档合并的代码吗?

我的是java;这样可以么

private void mergeWord(Document mainDoc, Map<String, Document> childFileMap) throws Exception {
        DocumentBuilder builder = new DocumentBuilder(mainDoc);
        for (Map.Entry<String, Document> entry : childFileMap.entrySet()) {
            Bookmark bm = mainDoc.getRange().getBookmarks().get(entry.getKey());

            if (bm != null) {
                builder.moveToBookmark(entry.getKey());
                bm.setText("");
                bm.remove();
            } else {
                builder.moveToDocumentEnd();
            }

            builder.insertBreak(BreakType.PAGE_BREAK);
            builder.insertDocument(entry.getValue(), ImportFormatMode.KEEP_SOURCE_FORMATTING);
        }
    }

我的是java;这个是word拼接的代码

private void mergeWord(Document mainDoc, Map<String, Document> childFileMap) throws Exception {
        DocumentBuilder builder = new DocumentBuilder(mainDoc);
        for (Map.Entry<String, Document> entry : childFileMap.entrySet()) {
            Bookmark bm = mainDoc.getRange().getBookmarks().get(entry.getKey());
            if (bm != null) {
                builder.moveToBookmark(entry.getKey());
                bm.setText("");
                bm.remove();
            } else {
                builder.moveToDocumentEnd();
            }
            builder.insertBreak(BreakType.PAGE_BREAK);
            builder.insertDocument(entry.getValue(), ImportFormatMode.KEEP_SOURCE_FORMATTING);
        }
    }

@liujing111, 您需要将页眉和页脚从第二个文档手动复制到第一个文档。 请看这个例子:

Document mainDoc = new Document("第一个word.doc");
Document secondDoc = new Document("第二个word(带aspose生成的页码和目录).doc");
HashMap<String, Document> childFileMap = new HashMap<String, Document>();
childFileMap.put("second", secondDoc);

DocumentBuilder builder = new DocumentBuilder(mainDoc);
for (Map.Entry<String, Document> entry : childFileMap.entrySet()) {
    Bookmark bm = mainDoc.getRange().getBookmarks().get(entry.getKey());
    if (bm != null) {
        builder.moveToBookmark(entry.getKey());
        bm.setText("");
        bm.remove();
    } else {
        builder.moveToDocumentEnd();
    }
    builder.insertBreak(BreakType.PAGE_BREAK);
    builder.insertDocument(entry.getValue(), ImportFormatMode.USE_DESTINATION_STYLES);

    MergeHeaderFooter(secondDoc, mainDoc, HeaderFooterType.FOOTER_PRIMARY);
}

mainDoc.updateFields();
mainDoc.save("merged.docx");


public static void MergeHeaderFooter(Document srcDoc, Document dstDoc, int headerType) throws Exception
{
    for (Section section : dstDoc.getSections())
    {
        HeaderFooter header = section.getHeadersFooters().getByHeaderFooterType(headerType);
        if (header == null)
        {
            // There is no header of the specified type in the current section, create it.
            header = new HeaderFooter(section.getDocument(), headerType);
            section.getHeadersFooters().add(header);
        }
        for (var srcNode : (Iterable<Node>)srcDoc.getFirstSection().getHeadersFooters().getByHeaderFooterType(headerType).getChildNodes())
        {
            Node dstNode = dstDoc.importNode(srcNode, true, ImportFormatMode.KEEP_SOURCE_FORMATTING);
            header.appendChild(dstNode);
        }
    }
}


merged.docx (92.4 KB)
但是这样的话第一个文档也会有页码,现在是第一个文档不要页码,第二个文档要页码,需要怎么写;或者有没有先将两个文档合并,再把合并后的文档从第几页开始生成页码,有没有此种方案

@liujing111, 在这种情况下,您可以在第二个文档之前开始一个新部分。 这将产生您想要的结果。

Document mainDoc = new Document("第一个word.doc");
Document secondDoc = new Document("第二个word(带aspose生成的页码和目录).doc");
HashMap<String, Document> childFileMap = new HashMap<String, Document>();
childFileMap.put("second", secondDoc);

DocumentBuilder builder = new DocumentBuilder(mainDoc);
for (Map.Entry<String, Document> entry : childFileMap.entrySet()) {
    Bookmark bm = mainDoc.getRange().getBookmarks().get(entry.getKey());
    if (bm != null) {
        builder.moveToBookmark(entry.getKey());
        bm.setText("");
        bm.remove();
    } else {
        builder.moveToDocumentEnd();

    }
   // Start a new section.
    builder.insertBreak(BreakType.SECTION_BREAK_NEW_PAGE);

    builder.insertDocument(entry.getValue(), ImportFormatMode.USE_DESTINATION_STYLES);
}

mainDoc.updateFields();

mainDoc.save("merged.docx");

您可能会在以下部分中找到有关页眉和页脚的有用解释:
https://forum.aspose.com/t/aspose-word-for-java/240765/10

builder.insertBreak(BreakType.SECTION_BREAK_NEW_PAGE);

builder.insertDocument(entry.getValue(), ImportFormatMode.USE_DESTINATION_STYLES);

这种方法也不行呢我试了下 @denis.shvydkiy

请问是哪里有问题吗 @denis.shvydkiy

@liujing111, 运行上面的代码会生成此文档,其页脚的页码从第 2 页开始。

merged.docx (92.4 KB)

您能否更具体地说明您遇到的问题是什么?

用这种方法,我的还是没有生成页码,是否是因为aspose的版本不一致呢,我的是20.6 @denis.shvydkiy

@liujing111, 我可以确认 Aspose.Words 20.6 没有产生所需的结果。 我建议您升级到最新的 Aspose.Words 版本。