谷歌分析API问题

3
我目前正在参与一个小组项目,其中我们使用Google Analytics来获取数据,并需要将API与Google Analytics结合起来用于我们正在创建的数据库。我们遇到了一个问题,无法使API正常工作。我们需要一个视图ID,但是我们却无法弄清如何创建仅包含Web Property的帐户,因为它根本没有给我们创建Web Property的选项。每次尝试创建新帐户时,它都会将我们放入Analytics for App和Web Properties的beta版中,该版本不提供视图ID。
我们也尝试创建一个新的Google账户,但这并没有起作用。
下面附上我们的代码,如果有人可以帮助我们绕过这个问题,或告诉我们需要怎么做才能创建仅包含Web Property的帐户,我们将不胜感激! 我们使用Python编写代码,并使用Jupyter
#Load Libraries
from oauth2client.service_account import ServiceAccountCredentials
from apiclient.discovery import build
import httplib2
import pandas as pd

#Create service credentials
#Rename your JSON key to client_secrets.json and save it to your working folder
credentials = ServiceAccountCredentials.from_json_keyfile_name('client_secrets.json', 
['https://www.googleapis.com/auth/analytics.readonly'])

#Create a service object
http = credentials.authorize(httplib2.Http())
service = build('analytics', 'v4', http=http, discoveryServiceUrl= 
('https://analyticsreporting.googleapis.com/$discovery/rest'))
response = service.reports().batchGet(
body={
    'reportRequests': [
        {
            'viewId': '261713611', #Add View ID from GA
            'dateRanges': [{'startDate': '30daysAgo', 'endDate': 'today'}],
            'metrics': [{'expression': 'ga:sessions'}], 
            'dimensions': [{"name": "ga:pagePath"}], #Get Pages
            "filtersExpression":"ga:pagePath=~products;ga:pagePath!@/translate", #Filter by condition "containing products"
            'orderBys': [{"fieldName": "ga:sessions", "sortOrder": "DESCENDING"}], 
            'pageSize': 100
         }]
 }
).execute()

#create two empty lists that will hold our dimentions and sessions data
dim = []
val = []

#Extract Data
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:

    dimensions = row.get('dimensions', [])
    dateRangeValues = row.get('metrics', [])

    for header, dimension in zip(dimensionHeaders, dimensions):
        dim.append(dimension)

    for i, values in enumerate(dateRangeValues):
        for metricHeader, value in zip(metricHeaders, values.get('values')):
            val.append(int(value))

#Sort Data
val.reverse()
dim.reverse()

df = pd.DataFrame() 
df["Sessions"]=val
df["pagePath"]=dim
df=df[["pagePath","Sessions"]]
df

#Export to CSV
df.to_csv("page_by_session.csv")
1个回答

1
Google Analytics 数据 API v1 可以为 GA4 属性创建报告。请查看开发者网站。Google Analytics 报表 API v4 可以为 Universal Analytics (GA3) 视图创建报告(参考文档)。您编写的代码正在使用 Google Analytics 报表 v4。
因此,您有两个选择:
1. 向数据 API v1 发送请求。在您的网站上标记一个 GA4 属性。 2. 向报表 API v4 发送请求。在您的网站上标记 GA3 (Universal Analytics)。这指南展示如何创建一个 Universal Analytics 属性。今天默认的新属性是一个 GA3 属性。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接