首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Google分析内部服务器错误500

Google分析内部服务器错误500
EN

Stack Overflow用户
提问于 2022-08-01 15:49:34
回答 1查看 192关注 0票数 2

我正在尝试构建一个API调用来检索google分析数据。这个API调用正常工作,现在它返回错误:

https://analyticsreporting.googleapis.com/v4/reports:batchGet?alt=json时返回“遇到的内部错误”。详细信息:“遇到内部错误.”>

因此,我得到的代码的主体是谷歌分析(GA从现在起)文档,所以我不明白是怎么回事。我也不明白为什么它原来起作用了,但现在不行了。

有人能帮我理解我能做些什么来克服这个障碍吗?

编辑我删除了维度“日期”,它返回数据。但是,GA中的查询生成器说我可以使用日期作为维度--那么为什么ga:date会导致调用中断呢?

代码:

代码语言:javascript
复制
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)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-08-02 13:30:09

Google分析内部服务器错误500

是因为您的代码中有一个错误。

代码语言:javascript
复制
'dimensions':[{'name':'ga.date'},{'name':'ga:UserType'},{'name':'ga:sessionCount'}]
    }]

它的ga:date而不是ga.date

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73196379

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档