PNG JPG BMP TIFF PDF
Aspose.PDF  for Python

在Python SDK中向PDF的页眉添加文本

使用云Python SDK处理PDF文档中页眉中的文本的API。

Get Started

如何通过云Python SDK在PDF页眉中添加文本

为了在PDF的页眉中添加文本,我们将使用 Aspose.PDF Cloud Python SDK。此Cloud SDK帮助Python程序员使用Python编程语言通过Aspose.PDF REST API开发基于云的PDF创建、注释、编辑和转换应用程序。只需在Aspose for Cloud创建一个帐户并获取您的应用程序信息。一旦您拥有应用程序SID和密钥,您就可以使用Aspose.PDF Cloud Python SDK。如果python包托管在Github上,您可以直接从Github安装:

从Github安装


     
    pip install git+https://github.com/aspose-pdf-cloud/aspose-pdf-cloud-python.git

包管理器控制台命令

     
    pip install asposepdfcloud

通过Python在页眉中添加文本的步骤

Aspose.PDF Cloud开发人员可以轻松地用几行代码加载并在PDF的页眉中添加文本。

  1. 安装Python SDK
  2. 将PDF文档上传到Aspose Cloud服务器
  3. 从Aspose Cloud服务器下载处理后的PDF文档
  4. 在PDF文档的页面上附加一个新的文本页眉
 

使用Python在PDF页眉中添加文本


    import shutil
    import json
    import logging
    from pathlib import Path
    from asposepdfcloud import ApiClient, PdfApi, TextHeader, HorizontalAlignment, TextHorizontalAlignment

    # Configure logging
    logging.basicConfig(level=logging.INFO, format="%(asctime)s - %(levelname)s - %(message)s")

    class Config:
        """Configuration parameters."""
        CREDENTIALS_FILE = Path(r"C:\\Projects\\ASPOSE\\Pdf.Cloud\\Credentials\\credentials.json")
        LOCAL_FOLDER = Path(r"C:\Samples")
        PDF_DOCUMENT_NAME = "sample.pdf"
        LOCAL_RESULT_DOCUMENT_NAME = "output_sample.pdf"
        HEADER_VALUE = "New header Value"
        PAGE_NUMBER = 2

    class pdfHederFooter:
        """Class for managing PDF headers and footers using Aspose PDF Cloud API."""
        def __init__(self, credentials_file: Path = Config.CREDENTIALS_FILE):
            self.pdf_api = None
            self._init_api(credentials_file)

        def _init_api(self, credentials_file: Path):
            """Initialize the API client."""
            try:
                with credentials_file.open("r", encoding="utf-8") as file:
                    credentials = json.load(file)
                    api_key, app_id = credentials.get("key"), credentials.get("id")
                    if not api_key or not app_id:
                        raise ValueError("init_api(): Error: Missing API keys in the credentials file.")
                    self.pdf_api = PdfApi(ApiClient(api_key, app_id))
            except (FileNotFoundError, json.JSONDecodeError, ValueError) as e:
                logging.error(f"init_api(): Failed to load credentials: {e}")

        def upload_document(self):
            """ Upload a PDF document to the Aspose Cloud server. """
            if self.pdf_api:
                file_path = Config.LOCAL_FOLDER / Config.PDF_DOCUMENT_NAME
                try:
                    self.pdf_api.upload_file(Config.PDF_DOCUMENT_NAME, str(file_path))
                    logging.info(f"upload_document(): File {Config.PDF_DOCUMENT_NAME} uploaded successfully.")
                except Exception as e:
                    logging.error(f"upload_document(): Failed to upload file: {e}")

        def download_result(self):
            """ Download the processed PDF document from the Aspose Cloud server. """
            if self.pdf_api:
                try:
                    temp_file = self.pdf_api.download_file(Config.PDF_DOCUMENT_NAME)
                    local_path = Config.LOCAL_FOLDER / Config.LOCAL_RESULT_DOCUMENT_NAME
                    shutil.move(temp_file, str(local_path))
                    logging.info(f"download_result(): File successfully downloaded: {local_path}")
                except Exception as e:
                    logging.error(f"download_result(): Failed to download file: {e}")

        def append_text_header(self):
            """Append a new text header to the PDF document."""
            if self.pdf_api:
                new_header = TextHeader(
                    background = True,
                    horizontal_alignment = HorizontalAlignment.CENTER,
                    text_alignment = TextHorizontalAlignment.CENTER,
                    value = Config.HEADER_VALUE
                )

                try:
                    response = self.pdf_api.post_document_text_header(
                        Config.PDF_DOCUMENT_NAME, new_header
                    )
                    if response.code == 200:
                        logging.info(f"append_text_header(): Header '{new_header.value}' added to the document '{Config.PDF_DOCUMENT_NAME}'.")
                    else:
                        logging.error(f"append_text_header(): Failed to add header '{new_header.value}' to the document '{Config.PDF_DOCUMENT_NAME}'. Response code: {response.code}")
                except Exception as e:
                    logging.error(f"append_text_header(): Error while adding header: {e}")

        def append_text_header_page(self):
            """Append a new text header to the page on PDF document."""
            if self.pdf_api:
                new_header = TextHeader(
                    background = True,
                    horizontal_alignment = HorizontalAlignment.LEFT,
                    text_alignment = TextHorizontalAlignment.CENTER,
                    value = Config.HEADER_VALUE
                )

                try:
                    response = self.pdf_api.post_document_text_header(
                        Config.PDF_DOCUMENT_NAME, new_header, start_page_number=Config.PAGE_NUMBER, end_page_number=Config.PAGE_NUMBER
                    )
                    if response.code == 200:
                        logging.info(f"append_text_header_page(): Header '{new_header.value}' added to the page #{Config.PAGE_NUMBER}.")
                    else:
                        logging.error(f"append_text_header_page(): Failed to add header '{new_header.value}' to the document #{Config.PAGE_NUMBER}. Response code: {response.code}")
                except Exception as e:
                    logging.error(f"append_text_header_page(): Error while adding header: {e}")


    if __name__ == "__main__":
        pdf_header_footer = pdfHederFooter()
        pdf_header_footer.upload_document()
        pdf_header_footer.append_text_header()
        pdf_header_footer.append_text_header_page()
        pdf_header_footer.download_result()
 

处理PDF中的页眉

向PDF的页眉添加文本可以增强品牌、导航、安全性和专业性。它有助于组织文档、保持合规性和确保一致性,使其成为商务、法律、学术和技术文档的宝贵功能。 将页眉添加到PDF文档中,使用Aspose.PDF Cloud Python SDK

使用我们的Python库,您可以:

  • 合并PDF文档。
  • 拆分PDF文件。
  • 将PDF转换为其他格式,反之亦然。
  • 操作注释。
  • 处理PDF中的图像等。
  • 您可以尝试我们的免费应用程序在线测试功能。