Merge Documents
You can try to merge documents and view the results online at this link:
Aspose.Words - Merge Documents
To append documents using Aspose.Words, simply invoke the appendDocument() method of Document class and specify the second document to append at end.
Java
Document doc1 = new Document(dataDir + "doc1.doc");
Document doc2 = new Document(dataDir + "doc2.doc");
doc1.appendDocument(doc2, ImportFormatMode.KEEP_SOURCE_FORMATTING);
docx4j - Merge Documents
This sample demonstrates how the MergeDocx utility can be used to merge docx documents.
The MergeDocx utility is a paid extension to docx4j. Purchases of this extension support the docx4j project.
@see https://www.docx4java.org/blog/2010/11/merging-word-documents/ for more info, or @see https://www.plutext.com.
To run the utility, you simply pass it a list of the docx you want to merge; it returns a new pkg containing the merged documents.
Java
final static String[] sourceDocxNames = { "doc1.docx", "doc2.docx"};
static boolean save = true;
static String outputfilepath = dataDir +"OUT_MergeDocx.docx";
/**
* @param args
* @throws Docx4JException
*/
public static void main(String[] args) throws Docx4JException {
// Create list of docx packages to merge
List<WordprocessingMLPackage> wmlPkgList=new ArrayList<WordprocessingMLPackage>();
for (int i=0; i<sourceDocxNames.length; i++){
String filename = dataDir + sourceDocxNames[i] ;
System.out.println("Loading " + filename);
wmlPkgList.add(WordprocessingMLPackage
.load(new java.io.File(filename)));
}
try {
// Use reflection, so docx4j can be built
// by users who don't have the MergeDocx utility
Class<?> documentBuilder = Class.forName("com.plutext.merge.DocumentBuilder");
//Method method = documentBuilder.getMethod("merge", wmlPkgList.getClass());
Method[] methods = documentBuilder.getMethods();
Method method = null;
for (int j=0; j<methods.length; j++) {
System.out.println(methods[j].getName());
if (methods[j].getName().equals("merge")) {
method = methods[j];
break;
}
}
if (method==null) throw new NoSuchMethodException();
WordprocessingMLPackage resultPkg = (WordprocessingMLPackage)method.invoke(null, wmlPkgList);
if (save) {
SaveToZipFile saver = new SaveToZipFile(resultPkg);
saver.save(outputfilepath);
System.out.println("Generated " + outputfilepath);
} else {
String result = XmlUtils.marshaltoString(resultPkg.getMainDocumentPart().getJaxbElement(), true, true);
System.out.println(result);
}
} catch (SecurityException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
extensionMissing(e);
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (NoSuchMethodException e) {
extensionMissing(e);
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
}
Download Running Code
Download Sample Code
For more details, visit Appending Documents.