Google Claender APIの使い方をメモ
基本的にはSpread Sheetと同様
GCP側の設定
まずGCPでプロジェクトを作ったら、右のメニューバーから、APIとサービス=>有効なAPIとサービスを選択
data:image/s3,"s3://crabby-images/63279/6327924e7f7bb08782bebaa6a05eaa3a0d3f3da0" alt=""
APIとサービスの有効化を選択
data:image/s3,"s3://crabby-images/dec3d/dec3d95dca50504c9681daf4770428154a8befe7" alt=""
calenderで検索するとGoogle Calender APIが出てくるので選択し有効化
data:image/s3,"s3://crabby-images/b7e73/b7e736fe019503660a45e487d1ead04543bd43bf" alt=""
サービスアカウント管理を選択
data:image/s3,"s3://crabby-images/e80ad/e80ad8cbc9fbb8d9519d122bdfbe1143b1d1cf20" alt=""
サービスアカウントを作成を選択
data:image/s3,"s3://crabby-images/6d87b/6d87b1bed7dd8b3894d0972b890e0df5940edecf" alt=""
情報を適当(任意の値)に入力し作成
data:image/s3,"s3://crabby-images/62e7b/62e7bb9a826039f634fae89b65aafc6ef4a4b942" alt=""
入力完了した認証情報が、作成されるので選択
data:image/s3,"s3://crabby-images/16ed9/16ed90377c4ae4e5082cc9dab59bc3aa24ea4c5a" alt=""
キー=>鍵を追加=>新しい鍵を作成を選択
data:image/s3,"s3://crabby-images/2e380/2e38020626a78148a5760e7ae65ab8ca3b54377b" alt=""
JSONで選択すると自動でcrendentialファイルがダウンロードされる
※1回しか発行されないので管理に注意(再作成は可能だが別物になる)
Calender側の設定
Calenderの設定メニューを選択
data:image/s3,"s3://crabby-images/1ee2e/1ee2e10316d376d7c1e0013fdc3cb7c699698a73" alt=""
予定のアクセス権限からユーザーを追加を選択
data:image/s3,"s3://crabby-images/d2b8e/d2b8ef366f1e5c17d377e5d8981208c17a795578" alt=""
メールアドレスに先ほどのサービスアカウントを入力
権限は変更及び共有の管理権限を選択
data:image/s3,"s3://crabby-images/75cd1/75cd11e8b872186d2ab9e005f9b2a85daf230bd3" alt=""
Google APIを利用
Pythonで記述。Google APIで認証しながら進めていく。
必要なライブラリをインストール
pip install google-api-python-client google-auth-httplib2 google-auth-oauthlib
カレンダー取得コード例
import datetime
from googleapiclient.discovery import build
from google.oauth2 import service_account
#設定値
SCOPES = ['https://www.googleapis.com/auth/calendar']
calendar_id = 'hogehoge'
conf_path = 'fugafuga'
def main():
#認証
creds =service_account.Credentials.from_service_account_file(conf_path, scopes=SCOPES)
service = build('calendar', 'v3', credentials=creds)
now = datetime.datetime.utcnow().isoformat() + 'Z'
#直近10件を取得
events_list = service.events().list(
calendarId=calendar_id,
timeMin=now,
maxResults=10,
singleEvents=True,
orderBy='startTime'
).execute()
if __name__ == '__main__':
main()
結果はjsonで出力される
コメント