我正在尝试构建一个API调用来检索google分析数据。这个API调用正常工作,现在它返回错误:
https://analyticsreporting.googleapis.com/v4/reports:batchGet?alt=json时返回“遇到的内部错误”。详细信息:“遇到内部错误.”>
因此,我得到的代码的主体是谷歌分析(GA从现在起)文档,所以我不明白是怎么回事。我也不明白为什么它原来起作用了,但现在不行了。
有人能帮我理解我能做些什么来克服这个障碍吗?
编辑我删除了维度“日期”,它返回数据。但是,GA中的查询生成器说我可以使用日期作为维度--那么为什么ga:date会导致调用中断呢?
代码:
from apiclient.discovery import build
from oauth2client.service_account import ServiceAccountCredentials
import sys
import os
from mymodules import ODBC, SendEmail, MyLogging
from dotenv import load_dotenv, find_dotenv
package_name = os.path.basename(__file__)
load_dotenv(find_dotenv())
logger = MyLogging.NewLogger(__file__, use_cd=True)
logger.info(f'Beginning package GAUSers.py')
SCOPES = ['https://www.googleapis.com/auth/analytics.readonly']
KEY_FILE_LOCATION = 'pathTo\client_secrets.json'
VIEW_ID = 'viewID'
def initialize_analyticsreporting():
credentials = ServiceAccountCredentials.from_json_keyfile_name(
KEY_FILE_LOCATION, SCOPES)
analytics = build('analyticsreporting', 'v4', credentials=credentials)
return analytics
def get_report(analytics):
return analytics.reports().batchGet(
body={
'reportRequests': [
{
'viewId': VIEW_ID,
'dateRanges':[{'startDate':'2022-07-01','endDate':'yesterday'}],
'metrics': [{'expression':'ga:users'},{'expression':'ga:newUsers'},{'expression':'ga:percentNewSessions'},{'expression':'ga:sessionsPerUser'}],
'dimensions':[{'name':'ga.date'},{'name':'ga:UserType'},{'name':'ga:sessionCount'}]
}]
}
).execute()
def print_response(response):
for report in response.get('reports', []):
columnHeader = report.get('columnHeader', {})
dimensionHeaders = columnHeader.get('dimensions', [])
metricHeaders = columnHeader.get('metricHeader', {}).get('metricHeaderEntries', [])
for row in report.get('data', {}).get('rows', []):
dimensions = row.get('dimensions', [])
dateRangeValues = row.get('metrics', [])
for header, dimension in zip(dimensionHeaders, dimensions):
print(header + ': ', dimension)
for i, values in enumerate(dateRangeValues):
print('Date range:', str(i))
for metricHeader, value in zip(metricHeaders, values.get('values')):
print(metricHeader.get('name') + ':', value)
try:
analytics = initialize_analyticsreporting()
#error happens here
response = get_report(analytics)
print_response(response)
except Exception as e:
logger.info(str(e) + '\n')
to_emails = os.getenv('Error_ToEmail').split(',')
body = f'Error running package {package_name}\n \
Error message: ' + str(e)
SendEmail.SendEmail(to_emails, 'Python Error', body)发布于 2022-08-02 13:30:09
Google分析内部服务器错误500
是因为您的代码中有一个错误。
'dimensions':[{'name':'ga.date'},{'name':'ga:UserType'},{'name':'ga:sessionCount'}]
}]它的ga:date而不是ga.date
https://stackoverflow.com/questions/73196379
复制相似问题