复制外部字段

Contents
[ ]

有时,PDF 表单需要在文档之间复用字段。使用 Aspose.PDF for Python,开发者可以通过编程方式将表单字段从源 PDF 复制到目标 PDF。

FormEditor 类提供了 \u0027copy_outer_field\u0027 方法,该方法将在指定页面和坐标处将字段从源文档复制到目标文档。

代码创建一个新的 PDF(目标),添加一个页面,然后将现有 PDF(源)中的字段复制到目标文档的指定坐标处。

  1. 创建一个新的目标 PDF 文档。
  2. 至少向目标 PDF 添加一页。
  3. 保存空的目标文档。
  4. 创建一个 FormEditor 对象并将其绑定到目标 PDF。
  5. 将源 PDF 中的 ‘First Name’ 字段复制到第 1 页的坐标 (200, 600)。
  6. 保存更新后的目标 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)
  • ‘original_field_name’ — 您想要复制的字段。
  • ’new_field_name’ – 新字段的名称。
  • ‘page_number’ – 新字段将出现的页码。
  • x, y – 该页上的坐标。

page_number 应为正整数,对应于 PDF 中已存在的页(基于 1 的索引)。

如果传入负数参数,例如:

form_editor.copy_outer_field("First Name", "First Name Copy", 1, -200, 600)

程序将恢复到之前的参数。