Проблемы с примером HelloAnalytics.py из Analytics Reporting API v4

образец кода на официальная веб-страница быстрого запуска устарела и не работает .

Поскольку Google поощряет использование StackOverflow, я не только надеюсь на помощь по следующим вопросам: но чтобы мотивировать Google обновить свой образец кода.

  • Я установил клиент google-api-python-client (без sudo, кстати).

  • SERVICE_ACCOUNT_EMAIL больше нет (в течение многих лет).

  • В качестве KEY_FILE_LOCATION я ввел имя JSON-файла. Это то, что вы подразумеваете под «соответствующими значениями из консоли разработчика»?

  • Я исправил функции печати в строке 65, 68 и 70 (что также сбило с толку других, особенно потому, что Python 2.7 устарел для google-api -python-client).

Если я запустил это, я получаю следующую ошибку:

Traceback (most recent call last):
  File "/Users/ralf/code/test_snippets/20-06-17_google_analytics_api/HelloAnalytics.py", line 4, in <module>
    from oauth2client.service_account import ServiceAccountCredentials
ModuleNotFoundError: No module named 'oauth2client'

Очевидно, отсутствует импорт. oauth2client устарел, и они рекомендуют google-auth и oauthlib.

Как я могу заставить это работать? Мы приветствуем любые подсказки, и Google, пожалуйста, исправьте этот образец кода, чтобы уберечь других от утомительных и утомительных исследований.

Спасибо!


person Ralf Zosel    schedule 17.06.2020    source источник
comment
Вы связали ту, что для сервисных аккаунтов, она и для установленных приложений отключена? developers.google.com/analytics/devguides/reporting/ core / v4 / Я связался с командой по поводу того, что образец требует обновления, спасибо за отчет.   -  person DaImTo    schedule 17.06.2020
comment
Мой контакт в Google еще раз благодарит и следите за новой версией, которая должна выйти в эфир завтра   -  person DaImTo    schedule 18.06.2020
comment
Извините за беспокойство, но, насколько я понимаю, там все еще есть старая версия в сети. Не могли бы вы спросить своего контактного еще раз? Большое спасибо!   -  person Ralf Zosel    schedule 23.06.2020


Ответы (1)


Пример кода был обновлен Google (благодаря DaImTo) и выглядит следующим образом:

"""Hello Analytics Reporting API V4."""

from apiclient.discovery import build
from oauth2client.service_account import ServiceAccountCredentials


SCOPES = ['https://www.googleapis.com/auth/analytics.readonly']
KEY_FILE_LOCATION = '<REPLACE_WITH_JSON_FILE>'
VIEW_ID = '<REPLACE_WITH_VIEW_ID>'


def initialize_analyticsreporting():
  """Initializes an Analytics Reporting API V4 service object.

  Returns:
    An authorized Analytics Reporting API V4 service object.
  """
  credentials = ServiceAccountCredentials.from_json_keyfile_name(
      KEY_FILE_LOCATION, SCOPES)

  # Build the service object.
  analytics = build('analyticsreporting', 'v4', credentials=credentials)

  return analytics


def get_report(analytics):
  """Queries the Analytics Reporting API V4.

  Args:
    analytics: An authorized Analytics Reporting API V4 service object.
  Returns:
    The Analytics Reporting API V4 response.
  """
  return analytics.reports().batchGet(
      body={
        'reportRequests': [
        {
          'viewId': VIEW_ID,
          'dateRanges': [{'startDate': '7daysAgo', 'endDate': 'today'}],
          'metrics': [{'expression': 'ga:sessions'}],
          'dimensions': [{'name': 'ga:country'}]
        }]
      }
  ).execute()


def print_response(response):
  """Parses and prints the Analytics Reporting API V4 response.

  Args:
    response: An Analytics Reporting API V4 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)


def main():
  analytics = initialize_analyticsreporting()
  response = get_report(analytics)
  print_response(response)

if __name__ == '__main__':
  main()

К сожалению, я все еще получаю сообщение об ошибке:

Exception has occurred: HttpError
<HttpError 403 when requesting https://analyticsreporting.googleapis.com/v4/reports:batchGet?alt=json returned "User does not have sufficient permissions for this profile.">
  File "/Users/ralf/code/test_snippets/20-07-01_google_analytics_api/HelloAnalytics.py", line 42, in get_report
    'dimensions': [{'name': 'ga:country'}]
  File "/Users/ralf/code/test_snippets/20-07-01_google_analytics_api/HelloAnalytics.py", line 75, in main
    response = get_report(analytics)
  File "/Users/ralf/code/test_snippets/20-07-01_google_analytics_api/HelloAnalytics.py", line 80, in <module>
    main()

Я выполнил шаги, описанные здесь осторожно, особенно Создать учетные данные и Добавить учетную запись службы в учетную запись Google Analytics, но явно что-то пошло не так. Я попробую еще раз позже.

person Ralf Zosel    schedule 01.07.2020