我使用google示例https://developers.google.com/sheets/api/samples/charts(出于测试目的,仅切换第3行和第4行)来使用Python v3.7.8测试Google Spreadshhet API v4:
数据存储在Google云端硬盘中的电子表格中,我在其中创建了柱形图。
柱形图已创建,但列“ A”未排序(升序)。以下代码:
from googleapiclient.discovery import build
from google_auth_oauthlib.flow import InstalledAppFlow
from google.auth.transport.requests import Request
...
body = {'requests': [
{'addChart':
{'chart':
{'spec':
{'title': 'Model Q1 Sales',
'titleTextPosition': {'horizontalAlignment': 'CENTER'},
'basicChart':
{'domains': [
{'domain':
{'sourceRange':
{'sources': [
{'sheetId': 909072886,
'startRowIndex': 0,
'endRowIndex': 7,
'startColumnIndex': 0,
'endColumnIndex': 1}]}}}],
'series': [
{'series':
{'sourceRange':
{'sources': [
{'sheetId': 909072886,
'startRowIndex': 0,
'endRowIndex': 7,
'startColumnIndex': 1,
'endColumnIndex': 2}]}},
'targetAxis': 'LEFT_AXIS'},
{'series':
{'sourceRange':
{'sources': [
{'sheetId': 909072886,
'startRowIndex': 0,
'endRowIndex': 7,
'startColumnIndex': 2,
'endColumnIndex': 3}]}},
'targetAxis': 'LEFT_AXIS'},
{'series':
{'sourceRange':
{'sources': [
{'sheetId': 909072886,
'startRowIndex': 0,
'endRowIndex': 7,
'startColumnIndex': 3,
'endColumnIndex': 4}]}},
'targetAxis': 'LEFT_AXIS'}],
'legendPosition': 'BOTTOM_LEGEND',
'axis': [
{'position': 'BOTTOM_AXIS',
'title': 'Model Numbers',
'titleTextPosition': {'horizontalAlignment': 'CENTER'}},
{'position': 'LEFT_AXIS',
'title': 'Sales',
'titleTextPosition': {'horizontalAlignment': 'CENTER'}}],
'headerCount': 1,
'chartType': 'COLUMN',
'stackedType': 'STACKED'},
'sortSpecs': [
{'dimensionIndex': 0,
'sortOrder': 'ASCENDING'}]},
'position':
{'overlayPosition':
{'anchorCell':
{'sheetId': 909072886,
'rowIndex': 7,
'columnIndex': 6}
}
}
}
}
}
]
}
response = service.spreadsheets().batchUpdate(spreadsheetId=file_id, body=body).execute()
我应该得到以下信息:
但是我明白了:排序部分没有任何作用。
备注:我也尝试了不成功的sortSpecs
'dataSourceColumnReference': {'name': 'A'}
代替
'dimensionIndex': 0
不要犹豫,支持我!先感谢您。
添加图表时,sortSpecs
仅支持来自外部数据源的数据。从API参考:
sortSpecs []:对图表数据进行排序的顺序。仅支持单个排序规范。仅支持数据源图表。
您应该对数据本身进行排序。您可以通过向您的添加一个sortRange请求来以编程方式执行此操作batchUpdate
:
body = {
'requests': [
{
'sortRange': {
'range': {
'sheetId': 909072886,
'startRowIndex': 1,
'endRowIndex': 7,
'startColumnIndex': 0,
'endColumnIndex': 5
},
'sortSpecs': [
{
'sortOrder': 'ASCENDING',
'dimensionIndex': 0
}
]
}
},
{
'addChart': {
# Add chart request body
}
}
]
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句