python google sheet API的无效JSON有效负载错误
Posted
技术标签:
【中文标题】python google sheet API的无效JSON有效负载错误【英文标题】:Invalid JSON Payload error with python google sheets API 【发布时间】:2017-11-26 03:46:26 【问题描述】:我正在尝试使用 google sheet API 将新行附加到现有的 google sheet。身份验证已经成功进行,并且代码能够读取工作表的内容。
但是,当我尝试使用 service.spreadsheets().values().append(...)
时,我得到以下 HttpError:"Invalid JSON payload received. Unknown name "": Root element must be a message."
这是我的代码:
from json import dumps as jsdumps
credentials = get_credentials()
http = credentials.authorize(httplib2.Http())
discoveryUrl = discoveryUrl = ('https://sheets.googleapis.com/$discovery/rest?version=v4')
service = discovery.build('sheets', 'v4', http=http, discoveryServiceUrl=discoveryUrl)
spreadsheetId = '...'
rangeName = "Sheet1"
value_input_option = 'RAW'
insert_data_option = 'INSERT_ROWS'
value_range_body =
"range": rangeName,
"majorDimension:": "ROWS",
"values": list(rd.values()), # rd is just a dictionary with some stuff in it
那么当我尝试发送它时:
request = service.spreadsheets().values().append(spreadsheetId=spreadsheetId, range=rangeName, valueInputOption=value_input_option, insertDataOption=insert_data_option, body=jsdumps(value_range_body))
运行request.execute()
后,我得到了上面列出的错误。
【问题讨论】:
您的“rangeName”变量似乎不完整。范围应类似于“Sheet1!A1:C3”。你试过那种格式吗? [meta] 我发现这个页面是这个页面的中文副本:xbuba.com/questions/44706584问题ID也与***上的匹配。很遗憾他们可能无法访问原始的 *** ,这可能是他们唯一的选择。由于政治造成了如此多的浪费。 【参考方案1】:我遇到了类似的问题。这对我有用:
spreadsheetId = 'foobar'
range = 'Sheet1!A1'
body =
'values': [data],
"majorDimension:": "ROWS",
self.service.spreadsheets().values().append(spreadsheetId=spreadsheet_id, range=range,
valueInputOption='RAW',
insertDataOption='INSERT_ROWS',
body=body).execute()
【讨论】:
以上是关于python google sheet API的无效JSON有效负载错误的主要内容,如果未能解决你的问题,请参考以下文章
python google sheet API的无效JSON有效负载错误
如何使用 Python 中的 API 重命名 Google Sheets 电子表格中的(工作)表?
如何使用API编辑google sheet而不需要手动登录?
如何使用 Google Sheets API V4 导入 CSV 文件