我真的很困惑如何写入公开的 Excel 表格。到目前为止,我已经下载了 Alamofire 和 GoogleAPIClientForREST cocoapods。所以我想知道,如果我想写信给工作表,我首先需要实现一个谷歌登录,还是我可以使用 Alamofire 发送数据。我非常迷茫,所以如果有人可以帮助我,那就太好了。
Google 表格:https://docs.google.com/spreadsheets/d/1zJR0uk6Pb6BuxJihFyxwe4ipQdBY4E9FFR74geBj8p0/edit#gid=0
func makeAndSendRequest() {
let baseUrl = "https://sheets.googleapis.com/v4/spreadsheets"
let spreadsheetId = "1zJR0uk6Pb6BuxJihFyxwe4ipQdBY4E9FFR74geBj8p0"
let params = ["valueInputOption": "RAW"]
let range = "Studen!A3:B3"
//need to add params
let url = baseUrl + "/" + spreadsheetId + "/values/" + range + "/valueInputOption=RAW/"
let fullUrl = URL(string: url)!
//my values
let requestParams = [
"values": [
1,
2
]
]
//my auth is after Bearer so "Bearer 901390"
let header = ["Authorization":"Bearer "]
let requestURL = "https://sheets.googleapis.com/v4/spreadsheets/\(spreadsheetId)/values/\(range)?valueInputOption=RAW"
let req = Alamofire.request(requestURL, method: .put, parameters: requestParams, encoding: JSONEncoding.default,headers: header)
req.responseJSON { response in debugPrint(response) }
}
尝试先解决这个问题。
valueInputOption
为查询参数,见:https://developers.google.com/sheets/api/reference/rest/v4/spreadsheets.values/update
你的网址至少应该是:
让 url = baseUrl + "/"+ spreadsheetId + "/values/"+ range + "?valueInputOption=RAW"
接下来您需要修正您的请求正文,此处需要每个文档的范围:https://developers.google.com/sheets/api/reference/rest/v4/spreadsheets.values/update
{
“范围”:“A3:B3”,
“值(value)观”:[
[
1、
2
]
]
}
此范围应与查询参数中的范围相同,例如 Sheet1!:A3:B3
与查询参数中的范围相同。
注意,它以工作表名称开头,不应该是“studen”
我在同一页面上使用了 Playground 工具,并且能够调用 api 来更改电子表格中的数据。
最后我得到 200 响应代码和以下 json:
{
“电子表格ID”:“1zJR0uk6Pb6BuxJihFyxwe4ipQdBY4E9FFR74geBj8p0”,
"updatedRange": "Sheet1!A3:B3",
“更新行”:1,
“更新的列”:2,
“更新的细胞”:2
}
----- 编辑 -----
如您所问,API 需要 Oauth token ,处理此问题的框架实际上称为 G Suite
请在此处找到指南: https://developers.google.com/gsuite/guides/ios
关于ios - 在 Swift 中写入 Google 表格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53293814/
欢迎光临 OStack程序员社区-中国程序员成长平台 (https://ostack.cn/) | Powered by Discuz! X3.4 |