data:image/s3,"s3://crabby-images/5a75a/5a75a4e6df011fab433bfd9db889be1c63f8e1d0" alt=""
Pythonとスプレッドシートを連携したいー!
この記事では、Google Sheets APIを使って、
Pythonでスプレッドシートにアクセスする方法をお伝えしていきます。
APIを使うことができれば、Pythonでスプレッドシートの情報を取得したり、逆にPythonで出力したデータをシートに書き込んだりする作業が可能になります。
- Google Sheets APIの取得方法
- Pythonとスプレッドシートの連携方法
- スプレッドシートへのアクセス許可方法
環境
OS | Mac 10.15.4 |
Python | python 3.9 |
仮想環境 | Poetry |
Homebrew | 8.0.19 Homebrew |
Google Cloud Platform のプロジェクト作成
今回は、Google API Platformでプロジェクトがある前提で、お伝えしていきます。
プロジェクト作成については、以下の記事の「プロジェクトの作成」の項目を参考にしてください。
data:image/s3,"s3://crabby-images/77ff3/77ff376274321d9ee07ee3136a7633b11b892a1c" alt=""
data:image/s3,"s3://crabby-images/77ff3/77ff376274321d9ee07ee3136a7633b11b892a1c" alt=""
スプレッドシートのAPIの取得
上記のURLから、Google Cloud Platformのライブラリに移行して、
スプレッドシートのアイコンを探します。(検索も可能です。)
APIの有効化
スプレッドシートAPIのページを見つけたら、Google Sheets APIを有効にします。
data:image/s3,"s3://crabby-images/562a0/562a09290ab62248be364e253e72986b12f7dc79" alt="Google Cloud Platform APIライブラリ GoogleSheetsAPI 有効にする"
data:image/s3,"s3://crabby-images/562a0/562a09290ab62248be364e253e72986b12f7dc79" alt="Google Cloud Platform APIライブラリ GoogleSheetsAPI 有効にする"
プロジェクトの秘密鍵の発行
ここでダウンロードしたjsonファイルは非常に重要なので、決して外部に出さないように注意してください
プロジェクトのページから、左側の鍵マーク → キー → 鍵の追加を選択します。
data:image/s3,"s3://crabby-images/ebf76/ebf76ef002973c570689ab1fa64c9a3790f3dae8" alt="Google Cloud Platform APIライブラリ GoogleSheetsAPI 有効にする"
data:image/s3,"s3://crabby-images/ebf76/ebf76ef002973c570689ab1fa64c9a3790f3dae8" alt="Google Cloud Platform APIライブラリ GoogleSheetsAPI 有効にする"
JSONを選択して、作成をします。
data:image/s3,"s3://crabby-images/e0f38/e0f38818d95e961ce32074ed8e11abe8df6dd427" alt="Google Cloud Platform GoogleSheetsAPI 秘密鍵の作成 JSON 作成"
data:image/s3,"s3://crabby-images/e0f38/e0f38818d95e961ce32074ed8e11abe8df6dd427" alt="Google Cloud Platform GoogleSheetsAPI 秘密鍵の作成 JSON 作成"
ダウンロードされるファイルは、次に説明する「プロジェクトのユーザー追加」で必要になります。
プロジェクトのユーザー追加
さきほどのJSONファイルをもとに、プロジェクトのユーザーを追加していきます。
先と同じ認証のページから、権限 → 新しいメンバー → サービスアカウント権限の選択 を設定します。
data:image/s3,"s3://crabby-images/35f9c/35f9c499aed23d9ecbc3d89d570b87731013f02e" alt="Google Cloud Platform GoogleSheetsAPI 権限 アクセスできるメンバーを追加"
data:image/s3,"s3://crabby-images/35f9c/35f9c499aed23d9ecbc3d89d570b87731013f02e" alt="Google Cloud Platform GoogleSheetsAPI 権限 アクセスできるメンバーを追加"
上記画像の2の「新しいメンバー」には、さきほどのjsonファイルに記載されているclient_emailの部分のアドレスを入力してください。
data:image/s3,"s3://crabby-images/0de86/0de865c85d4dd04db0bdf19a6f6d09009526a101" alt="Google Cloud Platform GoogleSheetsAPI jsonファイル client_email"
data:image/s3,"s3://crabby-images/0de86/0de865c85d4dd04db0bdf19a6f6d09009526a101" alt="Google Cloud Platform GoogleSheetsAPI jsonファイル client_email"
画像の3は「編集者」を選択しました。(スプレッドシートの権限と同じです)
メンバーの確認
作成をしたら、メンバーを確認します。
「ロール:オーナー」の下に、「ロール:編集者」の新しいメンバーが加わっているのを確認できました。
data:image/s3,"s3://crabby-images/4d17c/4d17c618b977e3b7d4e02961334ce77cedb5e40e" alt="Google Cloud Platform APIライブラリ GoogleSheetsAPI メンバー 編集者"
data:image/s3,"s3://crabby-images/4d17c/4d17c618b977e3b7d4e02961334ce77cedb5e40e" alt="Google Cloud Platform APIライブラリ GoogleSheetsAPI メンバー 編集者"
これでGoogle API Platformでの設定は完了です。
スプレッドシートの共有
ここで使った、client_emailのアドレスは、スプレッドシートの共有にも使います。
Pythonで連携したいスプレッドシートのページを開いて、右側の共有を選択します。
data:image/s3,"s3://crabby-images/a5f88/a5f8839865b6d1ba56ac45694af6b72275519648" alt=""
data:image/s3,"s3://crabby-images/a5f88/a5f8839865b6d1ba56ac45694af6b72275519648" alt=""
続いて、先ほどjsonファイルで取得したclient_emailのアドレスを入力して、完了を選択します。
xxxxxx@xxxxxxxxx.iam.gserviceaccount.com ←のようなアドレスです。
data:image/s3,"s3://crabby-images/bbe6e/bbe6e3e11d3194cc97b2e0641c5587e639833cdc" alt=""
data:image/s3,"s3://crabby-images/bbe6e/bbe6e3e11d3194cc97b2e0641c5587e639833cdc" alt=""
最後にユーザーに通知をするかが聞かれますが、通知をしてもどちらでも問題ありません。
jsonファイル設定と、ライブラリのインストール
Jsonファイルの設定
さきほど秘密鍵の発行でダウンロードしたjsonファイルを、client_secret.jsonというファイル名に変更しました。
(jsonファイルの内容は以下のようになっています)
{
"type": "service_account",
"project_id": "xxxxxxxxx-xxxxxxxx",
"private_key_id": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
"private_key": "-----BEGIN PRIVATE KEY-----\nxxxxxxxxxxxxxxxx\nxxxxxxxxxxxxxx\nxxxxxxxxxxxxxx\n-----END PRIVATE KEY-----\n",
"client_email": "xxxxxxxxxxxxxxxx@txxxxxxxxxxxxxxxxx.iam.gserviceaccount.com",
"client_id": "xxxxxxxxxxxxxxxxxxxxxxxxxx",
"auth_uri": "https://accounts.google.com/o/oauth2/auth",
"token_uri": "https://oauth2.googleapis.com/token",
"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
"client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/xxxxxxxxxxxxxxxxxxxxxxxxxxx.iam.gserviceaccount.com"
}
ライブラリのダウンロード
Poetryを使っている方は、ここを飛ばして、Poetryの環境設定を確認してください。
gspreadと、oauth2clientのモジュールをPythonにインストールします。
pip install gspread --ignore-installed six
pip install --upgrade oauth2client --ignore-installed six
poetryの環境設定
Poetryを使っていない方は上記で設定ができているので、飛ばしてください。
Poetryを使っている方は以下のコマンドでモジュールを追加してください。
poetry add gspread
poetry add oauth2client
これでPoetryの設定も完了です。
Pythonのスクリプト作成
Pythonで実行したいこと
今回は、下記のスプレッドシートの「A1セル」の取得したいと思います。
つまり、123 を取得できればクリアです。
data:image/s3,"s3://crabby-images/9fc89/9fc8932de8ffd2c14ca7eea89c91a6a94bc4d03f" alt=""
data:image/s3,"s3://crabby-images/9fc89/9fc8932de8ffd2c14ca7eea89c91a6a94bc4d03f" alt=""
Pythonのスクリプト作成:スプレッドシートの連携
コードは以下のスクリプトを作成しました。
#spreadsheet2.py
import gspread
from oauth2client.service_account import ServiceAccountCredentials
from pprint import pprint
scope = ["https://spreadsheets.google.com/feeds","https://www.googleapis.com/auth/spreadsheets","https://www.googleapis.com/auth/drive"]
creds = ServiceAccountCredentials.from_json_keyfile_name('client_secret.json',scope)
client = gspread.authorize(creds)
sheet = client.open_by_key('xxxxxxxxxxxxxxxxxxxxxxxx').sheet1
result = sheet.cell(1,1).value
print(result)
上記でPythonにスプレッドシートをどう連携させているの?
まず以下の2行は、先ほどダウンロードしたjsonファイル(client_secret.json)を指定しています。
creds = ServiceAccountCredentials.from_json_keyfile_name('client_secret.json',scope)
client = gspread.authorize(creds)
スプレッドシートの指定はどう設定しているの?
スプレッドシートの指定は以下で行っています。
sheet = client.open_by_key('xxxxxxxxxxxxxxxxxxxxxxxx').sheet1
スプレッドシートの指定方法はいくつかありますが、ここでは、Key を記載する方法を使っています。
keyはスプレッドシートのURL部分から得ることができます。
URLの、xxxxxxxxxxxxxxxxの部分です
https://docs.google.com/spreadsheets/d/xxxxxxxxxxxxxxxxxxxxxxxxx/edit#gid=0
data:image/s3,"s3://crabby-images/10fc9/10fc902cce08a1a024050df3955d6f473594b6a1" alt="Google Cloud Platform GoogleSheetsAPI スプレッドシート key URL"
data:image/s3,"s3://crabby-images/10fc9/10fc902cce08a1a024050df3955d6f473594b6a1" alt="Google Cloud Platform GoogleSheetsAPI スプレッドシート key URL"
スプレッドシートの情報はどう取得しているの?
以下のコードで、resultという変数に、シートのA1セルの情報を入れています。
A1のセルは、(1,1)で選択をしました。
result = sheet.cell(1,1).value
実行結果
123
data:image/s3,"s3://crabby-images/761a7/761a7482e91cc6cd26e00ca9c8196c89e0b035f8" alt=""
data:image/s3,"s3://crabby-images/761a7/761a7482e91cc6cd26e00ca9c8196c89e0b035f8" alt=""
data:image/s3,"s3://crabby-images/761a7/761a7482e91cc6cd26e00ca9c8196c89e0b035f8" alt=""
やった!A1セルの内容を取得することができた!
まとめ
Pythonでスプレッドシートを扱えるようになれば、スプレッドシートを使ったさまざま業務を自動化できる可能性があります。
僕自身も退屈だったGoogleアナリティクスの情報をなPythonを使って、
スプレッドシートに自動記入できるようにしましたが、
これが本当に便利で、プログラミングを勉強してよかったなと改めて実感しています。
参考
gspread Usageのページを記載しておきます。
スプレッドシートと連携する際に必要になるPythonの書き方が掲載されています。
コメント