看板 Google 關於我們 聯絡資訊
有連結可以點、有表情符號、其他沒差的 blog 版: https://pt2club.blogspot.com/2021/08/google-sheet-api-v3-v4.html ---------------------------------------------------------------------- 之前用這個網址格式取得 JSON 格式 Google Sheet 資料,一直相安無事: https://spreadsheets.google.com/feeds/list/SHEET_ID/ TAB_INDEX/public/values?alt=json 然後大概從 2021/8/15 開始,就有機率讀取不成功(對,有時候會成功 =.=), 有的時候是炸 CORS 問題、有的時候是炸 404。 狗了一下的結果,應該就是 Google Sheet API v3 在 2021/8/2 停用所導致的。 至於 v3 版跟應該還會繼續活著的 GData 有什麼關係、 為什麼是「有機率掛掉」就… 不研究… [蓋牌][翻白眼] 經過幾天的摸索,如果只是單純要取得 JSON,那麼會遇到下面這幾件事情。 首先要去 Google Cloud Platform 搞一個 API 金鑰(以下簡稱 API_KEY)。 如果之前沒有用過可能還要先開一個(看起來毫無意義的)專案然後才能產生… 有了 API 金鑰之後,接下來是把網址改成這個格式: https://sheets.googleapis.com/v4/spreadsheets/SHEET_ID/ values/RANGE&key=API_KEY 這邊不再是用「第幾個工作表」(或是那個根本不知道怎麼來的 id 值)的方式, 而是指定 RANGE。完整版的 RANGE 大概是「FOO!A1:D100」的長相, 這表示要求「FOO」這個工作表的 A1~D100 這個 cell 範圍的資料。 實測之後(找不到文件… )發現允許下列幾種變形: + FOO:可以省略 cell 範圍。如此會回傳整個 FOO 的資料 + A1:D100:可以省略工作表名稱。 如此會回傳第一個工作表的指定 cell 範圍的資料 回傳的 JSON 也跟以前不一樣,v4 版變得很純: { "range": "'FOO'!A1:D100", "majorDimension": "ROWS", "values": [ ["ColumnA", "欄位B", "ColumnC", "欄位D"], ["第一筆A", "第一筆B", "第一筆C", "第一筆D"], [], ["", "第三筆B"] } + v3 會把 sheet 的第一個 row 的值當成 JSON 的 key 值; v4 純粹就是給你一個二維字串陣列。(反正都能指定範圍了) + v3 遇到第一個空白 row 就會視為後面沒有資料停止輸出; v4 會在指定範圍內確定是否以下空白才停止輸出, 其中夾雜的空白行會給一個空陣列。 + 如果該 row 第 n 個 column 之後都沒有值, 則該 row 對應的陣列長度只到 n - 1。 1~n - 1 當中如果有 column 沒有值,會給空字串。 一樣是實測結果(還是找不到文件… ), 下列狀況會導致 server 給不是 200 的 HTTP status code: + 400:range 無法正常解析 + 403:API_KEY 值不正確 + 404:SHEET_ID 值不正確 最後,用 v4 版,sheet 可以不用做「發布到網路」這一個動作, 但是「共用」設定的「取得連結」要設定為「知道連結的使用者(檢視者)」 -- 錢鍾書: 說出來的話 http://www.psmonkey.org 比不上不說出來的話 Hiking / Singapore 板 只影射著說不出來的話 and more...... -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 218.166.173.181 (臺灣) ※ 文章網址: https://www.ptt.cc/bbs/Google/M.1629401330.A.B33.html
microloft: 不想處理金鑰的話還是可以繼續用發布到網路的方式 08/20 05:17
microloft: 然後自己 csv 轉 json 08/20 05:17
CSV 也太悲情了點 ※ 編輯: PsMonkey (36.239.87.32 臺灣), 08/21/2021 13:35:56
wang0424: 專業文 推一個 08/25 18:23