Запрошено 10 измерений;в API Google Analytics Core Reporting разрешено только 9 - PullRequest
0 голосов
/ 14 февраля 2019

Я пытался вызвать ядро ​​Google Analytics Reporting v4, чтобы получить базовые данные о трафике, но я никогда не мог получить группировку каналов по умолчанию / группировку каналов из API.Однако измерение доступно в соответствии с их метрикой и проводником измерений .

from googleapiclient.discovery import build
from oauth2client.service_account import ServiceAccountCredentials
import pandas as pd 

SCOPES = ['https://www.googleapis.com/auth/analytics.readonly']
KEY_FILE_LOCATION = r"event-source.json"
VIEW_ID = 'xxxxxxx'

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,
          'pageSize': 10000,
          'dateRanges':  [{'startDate':'7daysago' , 'endDate': 'yesterday'}],
          'metrics': [{'expression': 'ga:adCost'}],
          'dimensions': [{'name':'ga:year'},{'name':'ga:month'},{'name':'ga:date'},{'name':'ga:channelGrouping'},
                         {'name':'ga:source'},{'name':'ga:medium'},{'name':'ga:campaign'},{'name':'ga:adGroup'},
                         {'name':'ga:keyword'},{'name':'ga:adContent'}],
          'orderBys': [{"fieldName": "ga:date","sortOrder": "ASCENDING"}]
        }]
      }
    ).execute()

def print_response(response):
    lst=[]
    for report in response.get('reports', []):
        columnHeader = report.get('columnHeader', {})
        dimensionHeaders = columnHeader.get('dimensions', [])
        metricHeaders = columnHeader.get('metricHeader', {}).get('metricHeaderEntries', [])
        rows = report.get('data', {}).get('rows', [])

    for row in rows:
        dic={}
        dimensions = row.get('dimensions', [])
        dateRangeValues = row.get('metrics', [])

        for header, dimension in zip(dimensionHeaders, dimensions):
            dic[header] = dimension

        for i, values in enumerate(dateRangeValues):
            for metric, value in zip(metricHeaders, values.get('values')):
            #set int as int, float a float
                if ',' in value or ',' in value:
                    dic[metric.get('name')] = float(value)
                else:
                    dic[metric.get('name')] = int(value)

        lst.append(dic)

    df=pd.DataFrame(lst)
    return(df)     

Вот сообщение об ошибке, которое я получил:

HttpError: https://analyticsreporting.googleapis.com/v4/reports:batchGet?alt=json возвращено «Запрошено 10 измерений; разрешено только 9».>

Кто-нибудь, получивший такую ​​же ошибку, смог решить эту проблему?

1 Ответ

0 голосов
/ 14 февраля 2019

Запрошено 10 размеров;разрешено только 9.

означает, что именно при отправке 10 измерений вам разрешено отправлять только 9 вызовов API одновременно.Удалите одно из измерений ниже.Могу ли я предложить удалить {'name': 'ga: year'} и {'name': 'ga: month'}, когда вы уже запрашиваете дату, когда они вам действительно не нужны.

'dimensions': [{'name':'ga:year'},{'name':'ga:month'},{'name':'ga:date'},{'name':'ga:channelGrouping'},
                     {'name':'ga:source'},{'name':'ga:medium'},{'name':'ga:campaign'},{'name':'ga:adGroup'},
                     {'name':'ga:keyword'},{'name':'ga:adContent'}],
...