2021年4月13日 星期二

Google API - Python 學習筆記

Google API - python ver.

紀錄一些使用 python 呼叫 Google API 的心得

基本前置作業

  • Google Account
    首先你要有 google 帳號。
  • Google Cloud Platform project
    想要使用 Google Cloud Platform (GCP) 的 service,你需要創建一個 GCP project。左上角 project name 右邊的倒三角按下去新增。
  • Enable API
    旁邊的 API&Services => Library => 新增你想要的服務。不過我當初沒有用這步,應該是我用 Oauth 而非 API Keys 的關係 ( 完整介紹 )。
  • Credentials
    產生金鑰,我是選 Desktop App,然後下載其 json 檔就樣就好。雖然 Google Guide 其實有給很多講解及步驟,但我沒做也能運行。

安裝 google python api library

  • 安裝 google api python
    首先安裝 google-api-python-client,點進去有安裝方法,這裡用 Linux 做些紀錄。基本上是安裝一個 virtualenv,讓他新增一個獨立且乾淨的 python 執行環境,然後利用這虛擬環境去下載他門的 library。
        # 安裝虛擬 python 環境和 google-api-python-client
        pip install virtualenv
        virtualenv <your-env>
        source <your-env>/bin/activate
        <your-env>/bin/pip install google-api-python-client
  • 安裝 google_auth_oauthlib
    再來安裝 Oauth 2.0
        <your-env>/bin/pip install google_auth_oauthlib

安裝 google python api library

我寫這篇的主因,因為 google python api library 已經不再更新,有些 sample code 已經過時不能使用所以在這裡紀錄一些可用的 sample code。
  • Sample Code - flow
    這是 Google Oauth API Scope 我拿 blogger 做測試。完整的程式碼在 sample.py,輸出結果在 output.json。這裡擷取片段,順序還要參考完整的程式碼。 
        # 首先是連線設置,Flow 這個 class 是用來讀取你的 Credentials 來認證你的程式。
        # client_secrets.json = 你下載的 Oauth json file。
        # SCOPES = 你宣告要使用哪些功能 ( ex. gmail, blogger... )
        from google_auth_oauthlib.flow import InstalledAppFlow
        SCOPES = ['https://www.googleapis.com/auth/blogger']
        flow = InstalledAppFlow.from_client_secrets_file(
            'client_secrets.json', SCOPES)
    
        # 用 port 0 連線 GCP,這裡會用預設瀏覽器去做認證,結束後會跟你說可以關閉網頁
        creds = flow.run_local_server(port=0)
  • Sample Code - token
    這裡回傳值 creds,是 GCP 給的暫時性 token,若你的 token 還在且未過期,你就可以用此 token 直接連線而不用再透過瀏覽器認證。
        # 如果你有儲存 token,可以直接用 token 重新連線
        # token expired 的話且沒過太就的話可以用 creds.refresh(Request()) 做 refresh token
        creds = Credentials.from_authorized_user_file('token.json', SCOPES)
        if not creds.valid:
            if creds.expired and creds.refresh_token:
                creds.refresh(Request())
  • Sample Code - build
    這裡依照 Blogger API Guide 去做取資料。
        # 先依照 scope 取得服務,再依照 api 的格式去取得資料
        # posts() 跟 list() 都是依照 Blogger API Guide 去填寫的,最後執行 execute()
        # 回傳會是 dict,要自己轉 json
        from googleapiclient.discovery import build
        service = build('blogger', 'v3', credentials=creds)
        posts = service.posts().list(blogId=BLOGID,maxResults=3).execute()
參考資料 :
1.我跟Google官網

0 意見:

張貼留言

Popular Posts