Google Spread SheetをAPIで操作するためのメモ
Crendentialのjsonファイルをダウンロードする方法をメモ
GCPでAPIの許可を行う
Spread SheetをAPIで操作する場合、credentialキーが必要でGCPを通じて入手する必要がある。
GCPでプロジェクトを作ったら、右のメニューバーから、APIとサービス=>有効なAPIとサービスを選択。
data:image/s3,"s3://crabby-images/63279/6327924e7f7bb08782bebaa6a05eaa3a0d3f3da0" alt=""
APIとサービスの有効化を選択。
data:image/s3,"s3://crabby-images/c7453/c7453543841b716e3119c174fac72022e48a6897" alt=""
sheetと検索すると、Google Sheets APIが出てくるので選択。
data:image/s3,"s3://crabby-images/f6e82/f6e82f0b81f9f298dfff5c702483308ca3b83149" alt=""
有効化にするを選択。
data:image/s3,"s3://crabby-images/ebe34/ebe34bf670e2e20c0f30dd2ed0722e32c034ebfc" alt=""
APIとサービスページに戻り認証情報=>認証情報を作成=>サービスアカウントを選択。
data:image/s3,"s3://crabby-images/dce63/dce635ff27e9cc2722fe30b8c8e690fbe7379cf0" alt=""
情報を適当(任意の値)に入力し作成する。
data:image/s3,"s3://crabby-images/20388/2038830b84a9534051a721ff629970dc705eb514" alt=""
入力完了した認証情報が、作成されるので選択。
data:image/s3,"s3://crabby-images/3bd25/3bd254b4ad73b1c5e43373fe9c139dd8e0c15dab" alt=""
キー=>鍵を追加=>新しい鍵を作成を選択。
data:image/s3,"s3://crabby-images/2e380/2e38020626a78148a5760e7ae65ab8ca3b54377b" alt=""
JSONで選択すると自動でcrendentialファイルがダウンロードされる。
※1回しか発行されないので管理に注意(再作成は可能だが別物になる)
Spread Sheetで共有設定を行う
Spread Sheet側でAPIでの操作を許可するように設定を行う。
まずは適当なSpread Sheetを用意し、共有を選択。
data:image/s3,"s3://crabby-images/d0150/d0150e8983d94627939a49fbf18da1766337955d" alt=""
メールアドレスに先ほどのサービスアカウントを入力する。
data:image/s3,"s3://crabby-images/3bd25/3bd254b4ad73b1c5e43373fe9c139dd8e0c15dab" alt=""
data:image/s3,"s3://crabby-images/e9968/e996806aa8e5cacc67f210d312f399ae3cdfbe76" alt=""
APIで操作する
今回はpythonのgspreadを利用。
事前にspread sheetに値を適当に入力しておく。
data:image/s3,"s3://crabby-images/f9f28/f9f28e52a6294f3bb15d4e6990e6d8f6ad0d79b1" alt=""
pythonで操作。コードはこちら
import gspread
import pandas as pd
file_name = hoge
sheet_id = fuga
sheet_name = piyo
#gspread用のインスタンスを立ち上げる
gc = gspread.service_account(filename=file_name)
#spread sheetを選択。sheet_idはspread sheetの第三階層
#https://docs.google.com/spreadsheets/d/の後の部分)
#例:https://docs.google.com/spreadsheets/d/hogehogehoge/edit?hl=JA#gid=0
#↑hogehogehogeがsheet_id
sh = gc.open_by_key(sheet_id)
#シートを選択。sheet_nameはシートタブ名
worksheet = sh.worksheet(sheet_name)
#シートのデータをDataframe方式で出力
sheet_df = pd.DataFrame(worksheet.get_all_records(head=1))
出力してみる。
#>>> sheet_df
# sample
#0 1
spread sheetの中身を落とすことができた。
コメント