python - 要求 10 个维度;Google Analytics Core Reporting API4 只允许使用 9 个
问题描述
我一直试图调用谷歌分析核心报告 v4 来获取基本的流量数据,但我永远无法从 api 获得默认的频道分组/频道分组。但是,该维度可根据其metric 和 dimension explorer获得。
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 个。”>
有没有遇到同样错误的人能够解决这个问题?
解决方案
要求 10 个维度;只允许 9 个。
确切地说,您要发送 10 个维度,一次只能向 api 调用发送 9 个维度。删除以下尺寸之一。我可以建议删除 {'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'}],
推荐阅读
- javascript - Onclick 更改 HTML5 本地存储值
- google-app-engine - Google 搜索 API 通配符
- mysql - 查询未返回正确的数据
- javascript - 如何使用 javascript 或 jquery 在 Dynamics 365 中隐藏“添加传真”按钮
- hyperledger-fabric - CA 堆栈服务启动失败
- ios - iOS:检测或禁用多个图像选择
- node.js - 避免使用 Sequelize js 初始使用空表行。
- android - 请求带有android改造的soap wcf webService
- npm - 是否可以通过 gulp 脚本安装特定的 npm 库?
- php - Laravel 5.6 通过活动记录选择