这是代码,
import pandas as pd
from apiclient.discovery import build
from oauth2client.service_account import ServiceAccountCredentials
SCOPES = ['https://www.googleapis.com/auth/analytics.readonly']
KEY_FILE_LOCATION = './c-******-*******.json'
VIEW_ID = '*********'
def initialize_analyticsreporting():
credentials = ServiceAccountCredentials.from_json_keyfile_name(
KEY_FILE_LOCATION, SCOPES)
analytics = build('analyticsreporting', 'v4', credentials=credentials)
return analytics
#Get one report page
def get_report(analytics, pageTokenVar):
return analytics.reports().batchGet(
body={
'reportRequests': [
{
'viewId': VIEW_ID,
'dateRanges': [{'startDate': '3daysAgo', 'endDate': 'yesterday'}],
'metrics': [{'expression': 'ga:uniqueevents'}],
'dimensions': [{'name': 'ga:eventcategory' and 'ga:eventlabel'}],
'pageSize': 10000,
'pageToken': pageTokenVar,
'samplingLevel': 'LARGE'
}]
}
).execute()
def handle_report(analytics,pagetoken,rows):
response = get_report(analytics, pagetoken)
#Header, Dimentions Headers, Metric Headers
columnHeader = response.get("reports")[0].get('columnHeader', {})
dimensionHeaders = columnHeader.get('dimensions', [])
metricHeaders = columnHeader.get('metricHeader', {}).get('metricHeaderEntries', [])
#Pagination
pagetoken = response.get("reports")[0].get('nextPageToken', None)
#Rows
rowsNew = response.get("reports")[0].get('data', {}).get('rows', [])
rows = rows + rowsNew
print("len(rows): " + str(len(rows)))
#Recursivly query next page
if pagetoken != None:
return handle_report(analytics,pagetoken,rows)
else:
#nicer results
nicerows=[]
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')):
if ',' in value or ',' in value:
dic[metric.get('name')] = float(value)
else:
dic[metric.get('name')] = int(value)
nicerows.append(dic)
return nicerows
#Start
def main():
analytics = initialize_analyticsreporting()
global dfanalytics
dfanalytics = []
rows = []
rows = handle_report(analytics,'0',rows)
dfanalytics = pd.DataFrame(list(rows))
if __name__ == '__main__':
main()我的目标是向维度添加筛选器,我希望排除“(未设置)”结果,只包括“搜索”类型的事件。
我在#Get one report page中添加了几行代码,
我看了谷歌的文档,尝试了几个不同的行和选项,我真的不明白为什么它不能工作。
如果我删除这些行,代码就能完美地工作。
只要我添加以下几行代码:
'dimensionFilterClauses': [
{"filters": [{"dimensionName": "ga:eventlabel",
"operator": "EQUAL",
"expressions": [Recherche]}]
}
],我在‘of 'pageViews’中得到一个错误。
你有什么想法吗?
发布于 2020-11-17 20:59:30
尝试简化过滤器的语法,如下所示:
"filtersExpression":"ga:eventLabel!=(not set)"https://stackoverflow.com/questions/64269123
复制相似问题