我正在尝试在google official documentation之后在python 3中读取和写入不同工作表的值。虽然我可以使用下面提到的代码块中rangeName = 'Class Data!A2:E'
中的range属性从某些工作表中读取值:
discoveryUrl = ('https://sheets.googleapis.com/$discovery/rest?'
'version=v4')
service = discovery.build('sheets', 'v4', http=http,
discoveryServiceUrl=discoveryUrl)
spreadsheetId = '1BxiMVs0XRA5nFMdKvBdBZjgmUUqptlbs74OgvE2upms'
rangeName = 'Class Data!A2:E'
result = service.spreadsheets().values().get(
spreadsheetId=spreadsheetId, range=rangeName).execute()
values = result.get('values', [])
我正在尝试使用sample code from here编写值:
requests.append({
'updateCells': {
'start': {'sheetId': 0, 'rowIndex': 0, 'columnIndex': 0},
'rows': [
{
'values': [
{
'userEnteredValue': {'numberValue': 1},
'userEnteredFormat': {'backgroundColor': {'red': 1}}
}, {
'userEnteredValue': {'numberValue': 2},
'userEnteredFormat': {'backgroundColor': {'blue': 1}}
}, {
'userEnteredValue': {'numberValue': 3},
'userEnteredFormat': {'backgroundColor': {'green': 1}}
}
]
}
],
'fields': 'userEnteredValue,userEnteredFormat.backgroundColor'
}
})
batchUpdateRequest = {'requests': requests}
service.spreadsheets().batchUpdate(spreadsheetId=spreadsheet_id,
body=batchUpdateRequest).execute()
我面临的问题是我无法从官方文档中保留最新的工作表名称或id,并且由于最新的api版本正在使随机gid(我们可能不知道工作表的gid是什么)。有什么方法可以使用Google Sheet API v4来引用工作表列表或电子表格最新修订的工作表名称或ID?
最佳答案
您可以使用电子表格上的“获取”方法来获取工作表列表:
sheet_metadata = service.spreadsheets().get(spreadsheetId=spreadsheet_id).execute()
sheets = sheet_metadata.get('sheets', '')
title = sheets[0].get("properties", {}).get("title", "Sheet1")
sheet_id = sheets[0].get("properties", {}).get("sheetId", 0)
关于python - 在Python中获取Google电子表格api v4中的工作表列表和最新工作表,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/38245714/