如何使用 Python 將渲染的 HTML 範本插入 Google 文件

王林
發布: 2024-02-11 20:18:04
轉載
1284 人瀏覽過

如何使用 Python 将渲染的 HTML 模板插入 Google 文档

問題內容

我面臨一個挑戰,使用 python 以程式設計方式將 html 模板插入到 google 文件中。我知道 google 文檔編輯器或 google 文件 api 中沒有原生/內建功能可以解決我的問題,但我嘗試了一些技巧來達到我的目標。這裡我們忽略了我們應該插入文件中的“哪裡”,現在只要成功插入就足夠了。

我的方法是:

  1. 在 google 雲端硬碟上傳 html 文件,名稱為 application/vnd.google-apps.document,因為 google 文件會自動將 html 轉換為文件。 (不完美,但有效)
  2. 使用 google docs api get() 取得文件內容(google docs json 格式)。
  3. 使用 google 文件 batchupdate() 更新目標文件上的新內容。
def insert_template_to_file(target_file_id, content):
    media = MediaIoBaseUpload(BytesIO(content.encode('utf-8')), mimetype='text/html', resumable=True)
    body = {
        'name': 'document_test_html',
        'mimeType': 'application/vnd.google-apps.document',
        'parents': [DOC_FOLDER_ID]
    }

    try:
        # Create HTML as docs because it automatically convert html to docs
        content_file = driver_service.files().create(body=body, media_body=media).execute()
        content_file_id = content_file.get('id')

        # Collect html content from Google Docs after created
        doc = docs_service.documents().get(documentId=content_file_id, fields='body').execute()
        request_content = doc.get('body').get('content')

        # Insert the content from html to target file
        result = docs_service.documents().batchUpdate(documentId=target_file_id, body={'requests': request_content}).execute()
        print(result)

        # Delete html docs
        driver_service.files().delete(fileId=content_file_id).execute()
        print("Content inserted successfuly")
    except HttpError as error:
        # Delete html docs even if failed
        driver_service.files().delete(fileId=content_file_id).execute()
        print(f"An error occurred: {error}")
登入後複製

問題是:我從步驟 2 收集的內容與batchupdate() 所需的內容不符。我正在嘗試調整步驟 2 中的內容以匹配步驟 3,但尚未成功。

目標解決方案:取得帶有 html 程式碼的字串,插入呈現的 html 到 google 文件上的目標檔案。目標是將目標檔案的現有內容附加到 html,而不是覆蓋。

我的方法有意義嗎?您還有其他想法可以實現我的目標嗎?


正確答案


我相信您的目標如下。

  • 您希望透過呈現 html 將 html 資料附加到 google 文件。
  • 您希望使用適用於 python 的 googleapis 來實現此目的。

遺憾的是,現階段「method:documents.get」檢索到的json物件似乎無法直接用作「method:documents.batchupdate」的請求體。

但是,如果您想將 html 附加到現有的 google 文件中,我認為僅使用 drive api 即可實現。當這反映在範例腳本中時,下面的範例腳本怎麼樣?

範例腳本:

def insert_template_to_file(target_file_id, content):
    request = drive_service.files().export(fileId=target_file_id, mimeType="text/html")
    file = BytesIO()
    downloader = MediaIoBaseDownload(file, request)
    done = False
    while done is False:
        status, done = downloader.next_chunk()
        print("Download %d%%" % int(status.progress() * 100))
    file.seek(0)
    current_html = file.read()

    media = MediaIoBaseUpload(BytesIO(current_html + content.encode('utf-8')), mimetype='text/html', resumable=True)
    body = {'mimeType': 'application/vnd.google-apps.document'}

    try:
        result = drive_service.files().update(fileId=target_file_id, body=body, media_body=media).execute()
        print(result)
        print("Content inserted successfuly")
    except HttpError as error:
        print(f"An error occurred: {error}")
登入後複製
  • 在此修改後的腳本中,從現有 google 文件中檢索 html 數據,並將新的 html 附加到檢索到的 html 中。並且,google 文件透過更新的 html 進行更新。在你的情況下,原始數據似乎是 html。所以我覺得這個方法或許可以用。

注意:

  • 此腳本會覆寫 target_file_id 的 google 文件。因此,當您測試此腳本時,我建議您使用範例 google 文件。

參考文獻:

以上是如何使用 Python 將渲染的 HTML 範本插入 Google 文件的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:stackoverflow.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!