文書の挿入と追加
複数のドキュメントを1つに結合する必要がある場合があります。 これは手動で行うことも、Aspose.Words挿入または追加機能を使用することもできます。
挿入操作を使用すると、以前に作成されたドキュメントの内容を新規または既存のドキュメントに挿入できます。
次に、追加機能を使用すると、別の文書の最後にのみ文書を追加できます。
この記事では、さまざまな方法でドキュメントを別のドキュメントに挿入または追加する方法と、ドキュメントの挿入または追加時に適用できる共通のプロパティについて説明します。
文書を挿入する
上述したように、Aspose.Wordsでは、文書はノードのツリーとして表され、ある文書を別の文書に挿入する操作は、第一の文書ツリーから第二の文書ツリーにノードをコピーす
ドキュメントは、さまざまな場所にさまざまな方法で挿入できます。 たとえば、置換操作、マージ操作中の差し込み項目、またはブックマークを使用してドキュメントを挿入できます。
また、Microsoft Wordに文書を挿入するのと同様のInsertDocumentメソッドを使用して、以前のインポートを行わずに現在のカーソル位置に文書全体を挿入することもできます。Microsoft Wordに文書を挿入するのと同様の方法です。
次のコード例は、InsertDocument
メソッドを使用してドキュメントを挿入する方法を示しています:
次のサブセクションでは、あるドキュメントを別のドキュメントに挿入するためのオプションについて説明します。
検索および置換操作{#insert-a-document-during-find-and-replace-operation}中に文書を挿入する
検索および置換操作の実行中にドキュメントを挿入できます。 たとえば、ドキュメントには、[はじめに]と[結論]というテキストを含む段落を含めることができます。 しかし、最終的な文書では、それらの段落を別の外部文書から取得した内容に置き換える必要があります。 これを実現するには、replaceイベントのハンドラーを作成する必要があります。
次のコード例は、replacingイベントのハンドラーを作成して、挿入プロセスの後半で使用する方法を示しています:
次のコード例は、検索および置換操作中にあるドキュメントのコンテンツを別のドキュメントに挿入する方法を示しています:
Mail Merge操作{#insert-a-document-during-mail-merge-operation}中に文書を挿入する
Mail merge操作中に差し込み項目に文書を挿入できます。 たとえば、mail mergeテンプレートには[Summary]などの差し込み項目を含めることができます。 ただし、最終文書では、別の外部文書から取得したコンテンツをこの差し込み項目に挿入する必要があります。 これを実現するには、mergeイベントのハンドラーを作成する必要があります。
次のコード例は、mergingイベントのハンドラーを作成して、挿入プロセスの後半で使用する方法を示しています:
次のコード例は、createdハンドラーを使用して差し込み項目にドキュメントを挿入する方法を示しています:
ブックマークに文書を挿入する
テキストファイルをドキュメントにインポートして、ドキュメントで定義したブックマークの直後に挿入することができます。 これを行うには、ドキュメントを挿入するブックマークされた段落を作成します。
次のコーディング例は、ある文書の内容を別の文書のブックマークに挿入する方法を示しています:
文書を追加する
ドキュメントから既存のドキュメントの最後まで追加のページを含める必要があるユースケースがある場合があります。 これを行うには、AppendDocumentメソッドを呼び出してドキュメントを別のドキュメントの最後に追加するだけです。
次のコード例は、ドキュメントを別のドキュメントの末尾に追加する方法を示しています:
ノードの手動でのインポートと挿入
Aspose.Words以前のインポート要件を使用せずに、ドキュメントを自動的に挿入および追加できます。 ただし、セクションや段落など、文書の特定のノードを挿入または追加する必要がある場合は、まずこのノードを手動でインポートする必要があります。
あるセクションや段落を別のセクションや段落に挿入または追加する必要がある場合は、基本的にImportNodeメソッドを使用して最初のドキュメントノードツリーノードツリーのノードを2番目のノードにインポートする必要があります。 ノードをインポートした後、InsertAfter/InsertBeforeメソッドを使用して、参照ノードの後/前に新しいノードを挿入する必要があります。 これにより、ドキュメントからノードをインポートし、指定された位置に挿入することで、挿入プロセスをカスタマイズできます。
また、セクションレベルではなく段落レベルでコンテンツを追加する場合など、AppendChildメソッドを使用して、子ノードのリストの最後に新しい指定されたノードを追加することもできます。
次のコード例は、ノードを手動でインポートし、InsertAfterメソッドを使用して特定のノードの後に挿入する方法を示しています:
これは、ページ設定やヘッダーやフッターなどの設定がインポート中に保持されることを意味します。 また、文書を挿入または追加するときに書式設定を定義して、2つの文書を結合する方法を指定できることにも注意してください。
挿入文書と追加文書の共通プロパティ
InsertDocumentとInsertDocumentの両方 AppendDocument メソッドはImportFormatModeとImportFormatOptionsを入力パラメータとして受け入れます。 ImportFormatModeを使用すると、UseDestinationStyles、KeepSourceFormatting、KeepDifferentStylesなどの異なる書式モードを選択して、ある文書から別の文書にコンテンツをインポートするときに文書の書式をマージする方法を制 ImportFormatOptionsを使用すると、次のようなさまざまなインポートオプションを選択できますIgnoreHeaderFooter, IgnoreTextBoxes, KeepSourceNumbering, MergePastedLists, とSmartStyleBehavior。
Aspose.Wordsを使用すると、SectionおよびPageSetupプロパティを使用して、挿入または追加操作で二つの文書が一緒に追加されたときに、結果の文書の視覚化を調整できます。 PageSetupプロパティには、次のようなセクションのすべての属性が含まれていますSectionStart, RestartPageNumbering, PageStartingNumber, Orientation, と他の人。 最も一般的な使用例は、SectionStartプロパティを設定して、追加されたコンテンツが同じページに表示されるか、新しいページに分割されるかを定義することです。
次のコード例は、コンテンツが2つのページに分割されないようにしながら、あるドキュメントを別のドキュメントに追加する方法を示しています: