data:image/s3,"s3://crabby-images/ee2ca/ee2cae60e4606abda36ff09be116ecf5715e5db2" alt="使用 Python 將資料寫入 Google 試算表 使用 Python 將資料寫入 Google 試算表"
使用 Python 將資料寫入 Google 試算表
今天來介紹,如何使用 Python 連線到 Google 試算表,並將資料寫入進去。
要和 Google Sheets 連線,必須要使用到 gspread 和 oauth2client 套件,還有 Google Sheets API。
以下請跟著教學一步一步實作!
使用到的工具:
Python 版本:3.8.5
gspread 版本:3.7.0
oauth2client 版本:4.1.3
一、申請 Google Sheets API
1. 請輸入以下網址,登入 Google 的帳號後進入首頁。
https://console.developers.google.com
data:image/s3,"s3://crabby-images/25d72/25d7237165795b6f17552c142a906862c759fad9" alt=""
2. 輸入專案的名稱及 ID
data:image/s3,"s3://crabby-images/8c040/8c040d64f34ff3081dc74116e4286189c30dc607" alt=""
3. 點選上方的「啟用 API 和服務」
data:image/s3,"s3://crabby-images/11d7e/11d7e3fa6c4bd0a9897cf19bb818c5447be638ef" alt=""
4. 於搜尋框輸入「Google Sheets API」
data:image/s3,"s3://crabby-images/37bfb/37bfb95fba28cf0ab4b39f234b0eb28c4e85d2b3" alt=""
點選啟用
data:image/s3,"s3://crabby-images/94438/944386f001138bc81aa5da9dd99a4d51dc630cc3" alt=""
5. 啟用之後,點選於畫面左方,最底下的「憑證」,然後於右上方點選「建立憑證」。
data:image/s3,"s3://crabby-images/1fa69/1fa69c9820a29524fe28a2c71d304a9fe50c5e99" alt=""
選擇第二個「服務帳戶」
data:image/s3,"s3://crabby-images/e9bde/e9bde51fd43aa434b7c8dfc2cb71845ebcb536b4" alt=""
6. 輸入帳戶的詳細資料
data:image/s3,"s3://crabby-images/93d61/93d6147786d3475f51dc972e636594edba78d7a6" alt=""
二和三不用填,直接完成即可。
data:image/s3,"s3://crabby-images/8a4df/8a4dfc7e6615cc70f015762ef16276fa5404e93a" alt=""
7. 完成後,底下服務帳戶多了一個電子郵件地址。
data:image/s3,"s3://crabby-images/c6055/c6055936f21e7e12f28f6ed1fa7b4b48d16fba4f" alt=""
8. 請點選那個電子郵件地址,進入詳細資料頁面。
進入後於左方點選「服務帳戶」
data:image/s3,"s3://crabby-images/ce373/ce373d3e9e9fff4811ffe3409ce5d25408d7212d" alt=""
請先將電子郵件地址複製到記事本,等等試算表要共用時,要將此地址輸入。
9. 點選上方的「金鑰」,選擇「建立新的金鑰」。
data:image/s3,"s3://crabby-images/a1d91/a1d91e60f7eeec605d33188bbe2b236ecfd20597" alt=""
10. 選擇 JSON 後按建立
data:image/s3,"s3://crabby-images/940d5/940d537976eca04460506e71dfefe0729eb24696" alt=""
這個金鑰先存放在隨便一個資料夾,等等在建立 Python 檔案的時候,要放在同一個資料夾。
二、建立試算表並設定共用
1. 建立一個新的試算表
data:image/s3,"s3://crabby-images/b6173/b61735cdaa90e9fda59fc2434fef4b66f0b4e308" alt=""
2. 點選右上角的「共用」,把剛剛紀錄的電子郵件輸入。
data:image/s3,"s3://crabby-images/ec798/ec798b679f79db113c7d75b09f4ff0342ef7d142" alt=""
選為編輯者,傳送
data:image/s3,"s3://crabby-images/ea8ef/ea8efa22fed9c2e0daa5ca1492846ea670164af3" alt=""
三、安裝套件和撰寫程式碼
1. 開啟 Anaconda Prompt,輸入以下指令安裝套件:
pip install gspread oauth2client
data:image/s3,"s3://crabby-images/f41cc/f41cc7779f56139626fe29f58de79d20a6cb408d" alt=""
2. 將 Google 試算表 網址的代碼複製到記事本
data:image/s3,"s3://crabby-images/a6abd/a6abd55a0cc4b4a022b6181f2c91f642a136abb6" alt=""
3. 開啟 Spyder (或妳慣用的文字編輯器),建立一個新的 Python 檔案,並輸入以下程式碼:
import gspread
from oauth2client.service_account import ServiceAccountCredentials as SAC
data:image/s3,"s3://crabby-images/c4bcc/c4bcc043eafbc83ecdfb42750082c97ec03ba62e" alt=""
4. 設定 json 檔案路徑及程式操作範圍
Json = 'inbound-sight-311513-47edd249188c.json' # Json 的單引號內容請改成妳剛剛下載的那個金鑰
Url = ['https://spreadsheets.google.com/feeds']
data:image/s3,"s3://crabby-images/2cffa/2cffa217bf31424e3bf193e131b7f137d20e77bf" alt=""
5. 接著撰寫連線至資料表的 Code
Connect = SAC.from_json_keyfile_name(Json, Url)
GoogleSheets = gspread.authorize(Connect)
data:image/s3,"s3://crabby-images/905e7/905e7ebefbada03301c3e2acec124bf7b3b76a40" alt=""
ServiceAccountCredentials(因為太長所以直接取名成 SAC) 的 from_json_keyfile_name 方法,帶入兩個參數後給變數 Connect,再透過 gspread 套件的 authorize 方法,帶入參數 Connect,連線至資料庫。
6. 開啟資料表及工作表
Sheet = GoogleSheets.open_by_key('14hYfea45xVlp5eczXouYT-r54iUndGyCPBS9TD_rJyU') # 這裡請輸入妳自己的試算表代號
Sheets = Sheet.sheet1
data:image/s3,"s3://crabby-images/e2173/e2173ffd08f3e583d95c8464a405dfb3a0e8bcb8" alt=""
7. 寫入資料至 Google Sheets
dataTitle = ["會員 ID", "使用暱稱", "密碼"]
datas = ["Captain", "Picard", "5678"]
Sheets.append_row(dataTitle)
Sheets.append_row(datas)
print("寫入成功")
data:image/s3,"s3://crabby-images/dd99c/dd99c1116e797fa1f129d859dae1277d8d6cd395" alt=""
先設定好串列,再使用 append_row 方法,將資料寫入至 Google Sheets。
8. 使用 get_all_values() 方法,看能不能從 試算表 讀取到資料
print(Sheets.get_all_values())
data:image/s3,"s3://crabby-images/ded76/ded768bb3f24f62cf25c3af46459fb01d3333c5a" alt=""
有讀取到就是寫入和讀取都有成功
data:image/s3,"s3://crabby-images/c92e8/c92e8a3e8842884d9634eecb533c2de5a5010baf" alt=""
Google Sheets 也有資料進去了!
data:image/s3,"s3://crabby-images/0f5a5/0f5a5159716d7d9b040176d4a1c85d9414a10e47" alt=""
Python 完整程式碼:
# 匯入模組
import gspread
from oauth2client.service_account import ServiceAccountCredentials as SAC
# 設定 json 檔案路徑及程式操作範圍
Json = 'inbound-sight-311513-47edd249188c.json'
Url = ['https://spreadsheets.google.com/feeds']
# 連線至資料表
Connect = SAC.from_json_keyfile_name(Json, Url)
GoogleSheets = gspread.authorize(Connect)
# 開啟資料表及工作表
Sheet = GoogleSheets.open_by_key('14hYfea45xVlp5eczXouYT-r54iUndGyCPBS9TD_rJyU')
Sheets = Sheet.sheet1
# 寫入資料
dataTitle = ["會員 ID", "使用暱稱", "密碼"]
datas = ["Captain", "Picard", "5678"]
Sheets.append_row(dataTitle)
Sheets.append_row(datas)
print("寫入成功")
# 讀取資料
print(Sheets.get_all_values())
Python 執行範例:
如果覺得文章內容還不錯的話,麻煩請幫我點個讚!感謝
可以多點幾次喔~~
第一次點讚需使用 Google 或 Facebook 帳號註冊
data:image/s3,"s3://crabby-images/318b2/318b23aaaf7af158dab1df1ed2a2a6a16ee06698" alt="使用 App Inventor 讀取 XML 網頁資料 使用 App Inventor 讀取 XML 網頁資料"
data:image/s3,"s3://crabby-images/61c13/61c1305731cfd9c981cb0f23aedbd853134142a4" alt="App Inventor 將讀取的資料使用表格呈現 App Inventor 將讀取的資料使用表格呈現"