環境
- Mac OSX(El Capitan)
- Python 2.7
準備
Google Drive APIの発行
プロジェクトの作成
- プロジェクトが無い場合は右上のExampleの箇所から新規プロジェクトの作成を行います
data:image/s3,"s3://crabby-images/87d97/87d979ef7eed740e6663a902851a2b83a827c20c" alt="スクリーンショット 2016-04-11 22.46.14.png"
- プロジェクト名とIDを決める事が出来ます
data:image/s3,"s3://crabby-images/0242e/0242e0aca6c120c39d0c2fe7077761c31214d0d7" alt="スクリーンショット 2016-04-11 22.45.20.png"
API
- Google Developers ConsoleからGoogle Drive APIを有効にします
data:image/s3,"s3://crabby-images/768d1/768d13acf751f328b1a6d808043cbe5be4a76f07" alt="スクリーンショット 2016-04-11 22.29.31.png"
- APIを有効にしたら左の認証情報を選択し、認証情報を作成 -> サービスアカウントキーを選択します (サービスアカウントが無い場合は作成して下さい)
data:image/s3,"s3://crabby-images/68859/68859c89a2237d2c2f1ebe4c79988b5cc84d4c1e" alt="スクリーンショット 2016-04-11 22.30.48.png"
- JSONとP12形式が選択可能ですが、ここではJSONを利用します
data:image/s3,"s3://crabby-images/e5ce0/e5ce08e9b5b6fba30d0292e907c9971e6292b47c" alt="スクリーンショット 2016-04-11 22.36.07.png"
- 完了するとJSONファイルが自動的にダウンロードされます
スプレッドシート側の共有設定
- 使用するスプレッドシートの右上にある共有ボタンを押し、ダウンロードしたJSONファイルに記載されている
client_email
の欄のアドレスを入力します
data:image/s3,"s3://crabby-images/32b83/32b83666549e2afd17fc6d3c8523b5c268cdc250" alt="スクリーンショット 2016-04-11 22.53.04.png"
- id
urlのhttps://docs.google.com/spreadsheets/d/***********/edit
アスタリスク部分がidになります
Python
ライブラリのインストール
- ライブラリ
-
oauth2client
sudo pip install --upgrade oauth2client --ignore-installed six
-
gdata (google正規: 今回は使わない)
sudo pip install gdata --ignore-installed six
-
gspread (こちらの方が便利そうなので今回はこっちを使用します)
sudo pip install gspread --ignore-installed six
※ El Capitanでは System Integrity Protection (SIP)のせいでpipのinstallが失敗するので、--ignore-installed six
を最後に付けてます
Code
- 以前は
SignedJwtAssertionCredentials
クラスが使用されていたのですが、2016/02にライブラリのアップデートがありServiceAccountCredentials
を使うようになりました
import os
import gspread
from oauth2client.service_account import ServiceAccountCredentials
def main():
scope = ['https://spreadsheets.google.com/feeds']
doc_id = 'Your doc id'
path = os.path.expanduser("Path of json file")
credentials = ServiceAccountCredentials.from_json_keyfile_name(path, scope)
client = gspread.authorize(credentials)
gfile = client.open_by_key(doc_id)
worksheet = gfile.sheet1
records = worksheet.get_all_values()
for record in records:
print(record)
if __name__ == '__main__':
main()