はじまり
data:image/s3,"s3://crabby-images/99a47/99a47261b60e20de4fe3f264a754d9e5528c8f63" alt="リサちゃん"
あー、もう、どうなってんだぁ〜!?
data:image/s3,"s3://crabby-images/d734b/d734bfaa9b701bad2e45f6b6ecc792334d079e24" alt="135ml"
どうしたどうした?
data:image/s3,"s3://crabby-images/99a47/99a47261b60e20de4fe3f264a754d9e5528c8f63" alt="リサちゃん"
PythonでGoogleスプレッドシートを編集したいんだが、そのための認証が面倒でね・・・
どこで躓いたが分からなくなってしまったのだよ・・・!
data:image/s3,"s3://crabby-images/d734b/d734bfaa9b701bad2e45f6b6ecc792334d079e24" alt="135ml"
じゃあ、今回はPythonでスプレッドシートを使うために、
Google Cloud Platformで行う初期設定を書いてみるかあ。
data:image/s3,"s3://crabby-images/941ed/941ed27939daa03a66aa79a225d1f87ca7f9c269" alt="リサちゃん"
ヨロシク!
設定作業その1:Google Cloud PlatformでAPIを有効化する
まず、Google Cloud Platformでプロジェクトを作成します。(作成の過程は割愛します。)
そして、GCPのコンソール画面のサイドバーから以下の「ライブラリ」をクリックします。
data:image/s3,"s3://crabby-images/0a93a/0a93aecd92d46367c6ab4a10bb3c258c2df6a822" alt=""
以下の画面から、今回必要なAPIを有効化します。今回は2種類のAPIを有効化します。
data:image/s3,"s3://crabby-images/a2ef2/a2ef2d3d512a6fe995d3f738c4aa8e4fe3c94af9" alt=""
そして、「Google Drive API」と「Google Sheets API」を有効化します。
data:image/s3,"s3://crabby-images/be923/be9233e30e3bb2924c5d8fa89065e48ed04d2cd8" alt=""
data:image/s3,"s3://crabby-images/da958/da958f7c23d3cbcf42b27717865e1e76dcc84b07" alt=""
APIが追加できたかどうかを確認します。
今度は、「APIとサービス」の「ダッシュボード」をクリックして以下のような画面で確認します。
data:image/s3,"s3://crabby-images/0e557/0e557483c1e280bb97a9a594c9e0bd449c576d68" alt=""
設定作業その2:Google Cloud Platformで認証情報を設定する
外部アプリケーションからスプレッドシートにリクエストするためにクレデンシャル情報を設定します。
「認証情報を作成」をクリックして、「サービスアカウント」を選びます。
data:image/s3,"s3://crabby-images/15793/15793a9030282b1b41b82ae668317e93a9614c95" alt=""
サービスアカウントの設定画面になります。
data:image/s3,"s3://crabby-images/745a3/745a38fc1883d979bda3f87cd8ace67f0973b0e4" alt=""
編集者を選択します。
data:image/s3,"s3://crabby-images/175f1/175f113d52d32742b3d97f1902d669772e703bda" alt=""
ここは省略します。
data:image/s3,"s3://crabby-images/a257b/a257b8502aa2765f1611a926227029890b850446" alt=""
そして、作成したサービスアカウントを確認して、キーの出力を行います・・・
data:image/s3,"s3://crabby-images/c1ff4/c1ff4da2a62a4aa1ccadd61e2fe0d27834c8fcab" alt=""
「鍵を追加」→「新しい鍵を作成」の順番でクリックします。
data:image/s3,"s3://crabby-images/6772d/6772db436e2fe1ef236ca542531e0d67c482c475" alt=""
秘密鍵をJSONファイルとして作成します。「作成」をクリックする。
data:image/s3,"s3://crabby-images/e25a8/e25a8ad5a44d8bee1ad47fbdf04dd1137a46640e" alt=""
PCにJSONファイル形式のファイルが保存されます。
data:image/s3,"s3://crabby-images/3e0d6/3e0d60a5a54d89bb241d2536cab4c5a6a8516d05" alt=""
余談:Workload Identity 連携について
ちなみに、先程のサービスアカウントのキー出力の画面内の警告文に「代わりにWorkload Identity 連携を使用することをおすすめします。」と書いてありました。
data:image/s3,"s3://crabby-images/c1ff4/c1ff4da2a62a4aa1ccadd61e2fe0d27834c8fcab" alt=""
こちらの連携設定を行った記事は、こちらになっていますので、興味があればご参考ください。
今回の作業では必要ありません。
設定作業その3:Googleスプレッドシートを編集するための設定
権限追加するシートの右上の「共有」ボタンをクリックする。
data:image/s3,"s3://crabby-images/882a3/882a3d715d399c26d5ce2e9a128a302bf15d0a96" alt=""
IAM設定で追加したサービスアカウントのプリンシパルをコピペします。
そして、そのユーザーを編集者権限にして、送信をクリックします。
data:image/s3,"s3://crabby-images/d6dce/d6dce8865ad84757c7689bde8b6b824bf32bbe26" alt=""
確認作業:Pythonコードを実行してみる
設定作業を行った後は、こちらを試してみると動作確認できるかと思います。
import gspread
from oauth2client.service_account import ServiceAccountCredentials
def authorizeGSSToGetWorksheet(credentialJsonFileName : str, gssId : str, sheetName : str):
scope = ['https://spreadsheets.google.com/feeds','https://www.googleapis.com/auth/drive']
credentials = ServiceAccountCredentials.from_json_keyfile_name(credentialJsonFileName, scope)
gc = gspread.authorize(credentials)
worksheet = gc.open_by_key(gssId).worksheet(sheetName)
return worksheet
jsonKeyFileName = "先ほどダウンロードしたjsonファイルのフルパス"
gssId = "共有設定したスプレッドシートのID"
sheetName = "共有設定したスプレッドシート内の編集したいシート名"
worksheet = authorizeGSSToGetWorksheet(jsonKeyFileName, gssId, sheetName)
cellList = worksheet.findall("検索値")
print(cellList)
gssIdは、URLで言うと、”https://docs.google.com/spreadsheets/d/<この部分>/edit#gid=0″の部分になります。
上述のプログラムを実行してみると、こんな感じの値が返ってくると思うので、スプレッドシートにアクセスできることが確認できると思います。
[<Cell R350C4 'https://qiita.com/ny7760/items/9cdc3407dfda99c21ae1'>]
おしまい
data:image/s3,"s3://crabby-images/8cd52/8cd523698a10cf3612a45c9872a107a68daf4e5b" alt="リサちゃん"
ふい〜、何とか設定できたなあ〜
data:image/s3,"s3://crabby-images/d734b/d734bfaa9b701bad2e45f6b6ecc792334d079e24" alt="135ml"
Pythoから叩けるようになることで、スプレッドシートのデータをnumpyとmatplotlibと組み合わせられるようになります。
良ければ、試してみてください。
data:image/s3,"s3://crabby-images/4368a/4368a426c0ead78d32d663f55979f5166dc7e9a3" alt="リサちゃん"
よいぞ〜、よいぞ〜
以上になります!
コメント