首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >分析报告应用编程接口V4

分析报告应用编程接口V4
EN

Stack Overflow用户
提问于 2020-10-09 03:07:07
回答 1查看 228关注 0票数 1

这是代码,

代码语言:javascript
复制
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中添加了几行代码,

我看了谷歌的文档,尝试了几个不同的行和选项,我真的不明白为什么它不能工作。

如果我删除这些行,代码就能完美地工作。

只要我添加以下几行代码:

代码语言:javascript
复制
'dimensionFilterClauses': [
                            {"filters": [{"dimensionName": "ga:eventlabel",
                                          "operator": "EQUAL",
                                          "expressions": [Recherche]}]
                            }
                                        ],

我在‘of 'pageViews’中得到一个错误。

你有什么想法吗?

EN

回答 1

Stack Overflow用户

发布于 2020-11-17 20:59:30

尝试简化过滤器的语法,如下所示:

代码语言:javascript
复制
"filtersExpression":"ga:eventLabel!=(not set)"
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64269123

复制
相关文章

相似问题

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