外部フィールドをコピー
Contents
[
Hide
]
PDF フォームでは、ある文書のフィールドを別の文書で再利用する必要がある場合があります。Aspose.PDF for Python を使用すると、開発者はプログラムによってフォームフィールドをソース PDF からターゲット PDF にコピーできます。
ザの フォームエディター クラスには、ソースドキュメントからターゲットドキュメントの指定されたページと座標でフィールドをコピーする ‘copy_outer_field’ メソッドが用意されています。
このコードは、新しい PDF (ターゲット) を作成し、ページを追加し、既存の PDF (ソース) からターゲットドキュメントに指定された座標でフィールドをコピーします。
- 新しいターゲット PDF ドキュメントを作成します。
- ターゲット PDF に少なくとも 1 ページを追加します。
- 空のターゲットドキュメントを保存します。
- FormEditor オブジェクトを作成し、ターゲット PDF にバインドします。
- ソース PDF の「名前」フィールドを 1 ページ目の (200, 600) にコピーします。
- 更新したターゲット PDF を保存します。
from io import FileIO
import sys
from os import path
import aspose.pdf as ap
import aspose.pdf.facades as pdf_facades
sys.path.append(path.join(path.dirname(__file__), ".."))
from config import set_license, initialize_data_dir
def copy_outer_field(infile, outfile):
# Since copy_outer_field() method needs to copy field from source document to target document, we need to create a new document as target document first.
doc = ap.Document()
doc.pages.add()
doc.save(outfile)
# Create FormEditor object
form_editor = pdf_facades.FormEditor()
# Bind document to FormEditor
form_editor.bind_pdf(outfile)
# Copies an existing field to a new position specified by both page number and ordinates.
# A new document will be produced, which contains everything the source document has except for the newly copied field.
form_editor.copy_outer_field(infile, "First Name", 1, 200, 600)
# Save updated document
form_editor.save(outfile)
ご注意:
「copy_outer_field」メソッドのシグネチャは以下のようになります。
copy_outer_field(original_field_name, new_field_name, page_number, x, y)
- ‘元のフィールド名’ — 複製したいフィールド。
- ’new_field_name’ — 新しいフィールドの名前。
- ‘page_number’ — 新しいフィールドが表示されるページ。
- x, y — そのページの座標。
page_number は PDF 内の既存のページに対応する正の整数である必要があります (1 から始まるインデックス)。
負のパラメータを渡した場合、例:
form_editor.copy_outer_field("First Name", "First Name Copy", 1, -200, 600)
その後、プログラムは以前のパラメータにリセットされます。