在 Google 分析报告中使用过滤器 API
Using filters with the Google Analytics reporting API
以下代码应该能够按 EXACT eventCategory 进行过滤,但它不起作用。它 returns 所有事件都可用,当然有点乱。
/*
this querystring is what I'd like to receive, I've built it with the query explorer: https://ga-dev-tools.appspot.com/query-explorer/
ids=ga:private&
start-date=2017-05-01&
end-date=yesterday&
metrics=ga:eventValue,ga:avgEventValue&
dimensions=ga:subContinent,ga:eventCategory,ga:eventAction,ga:eventLabel&
filters=ga:eventCategory==video
*/
// Create the DateRange object.
$dateRange = new Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate("3daysago");
$dateRange->setEndDate("today");
// Create the Metrics object.
$ev = new Google_Service_AnalyticsReporting_Metric();
$ev->setExpression("ga:eventValue");
$ev->setAlias("EventValue");
$avg = new Google_Service_AnalyticsReporting_Metric();
$avg->setExpression("ga:avgEventValue");
$avg->setAlias("Avg Value");
//Create the dimensions
$sc = new Google_Service_AnalyticsReporting_Dimension();
$sc->setName("ga:subContinent");
$ec = new Google_Service_AnalyticsReporting_Dimension();
$ec->setName("ga:eventCategory");
$ea = new Google_Service_AnalyticsReporting_Dimension();
$ea->setName("ga:eventAction");
$el = new Google_Service_AnalyticsReporting_Dimension();
$el->setName("ga:eventLabel");
// Create the segment dimension.
$segmentDimensions = new Google_Service_AnalyticsReporting_Dimension();
$segmentDimensions->setName("ga:segment");
// Create Dimension Filter.
$dimensionFilter = new Google_Service_AnalyticsReporting_SegmentDimensionFilter();
$dimensionFilter->setDimensionName("ga:eventCategory");
$dimensionFilter->setOperator("EXACT");
$dimensionFilter->setExpressions(array("video"));
// Create Segment Filter Clause.
$segmentFilterClause = new Google_Service_AnalyticsReporting_SegmentFilterClause();
$segmentFilterClause->setDimensionFilter($dimensionFilter);
// Create the Or Filters for Segment.
$orFiltersForSegment = new Google_Service_AnalyticsReporting_OrFiltersForSegment();
$orFiltersForSegment->setSegmentFilterClauses(array($segmentFilterClause));
// Create the Simple Segment.
$simpleSegment = new Google_Service_AnalyticsReporting_SimpleSegment();
$simpleSegment->setOrFiltersForSegment(array($orFiltersForSegment));
// Create the Segment Filters.
$segmentFilter = new Google_Service_AnalyticsReporting_SegmentFilter();
$segmentFilter->setSimpleSegment($simpleSegment);
// Create the Segment Definition.
$segmentDefinition = new Google_Service_AnalyticsReporting_SegmentDefinition();
$segmentDefinition->setSegmentFilters(array($segmentFilter));
// Create the Dynamic Segment.
$dynamicSegment = new Google_Service_AnalyticsReporting_DynamicSegment();
$dynamicSegment->setSessionSegment($segmentDefinition);
$dynamicSegment->setName("video buffering");
// Create the Segments object.
$segment = new Google_Service_AnalyticsReporting_Segment();
$segment->setDynamicSegment($dynamicSegment);
// Create the ReportRequest object.
$request = new Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId(VIEW_ID);
$request->setDateRanges(array($dateRange));
$request->setSegments(array($segment));
$request->setDimensions(array($segmentDimensions,$sc,$ec,$ea,$el));
$request->setMetrics(array($ev, $avg));
// Create the GetReportsRequest object.
$getReport = new Google_Service_AnalyticsReporting_GetReportsRequest();
$getReport->setReportRequests(array($request));
// Call the batchGet method.
$body = new Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$response = $analyticsreporting->reports->batchGet( $body );
print_r($response);die;
根据当前请求,我得到的是:
Uncaught Google_Service_Exception: {
"error": {
"code": 400,
"message": "Invalid JSON payload received. Unknown name \"name\" at 'report_requests[0].dimensions[1]': Proto field is not repeating, cannot start list.",
"errors": [
{
"message": "Invalid JSON payload received. Unknown name \"name\" at 'report_requests[0].dimensions[1]': Proto field is not repeating, cannot start list.",
"domain": "global",
"reason": "badRequest"
}
],
"status": "INVALID_ARGUMENT"
}
}
这是我希望收到的经过编辑的数据子集:https://pastebin.com/L1pRgbn4
我知道这对聚会来说真的很晚,但我想也许它可以帮助其他人...我认为这是因为根据您的代码,您正在寻找一个片段,而不是一个过滤器。
There's a key difference between the two:
Segment – 对于一个segment,每次访问都会检查是否满足segment的条件。对于满足条件的会话,返回所有行。对于没有返回的会话,不会返回任何行。
Filter – 对于一个过滤器,考虑了ALL访问的所有行,然后只返回满足过滤器条件的行.
为了很好地回答您的问题 - 。
简而言之,您可能需要这样的东西:
// Create Dimension Filter.
$dimensionFilter = new
Google_Service_AnalyticsReporting_SegmentDimensionFilter();
$dimensionFilter->setDimensionName("ga:eventCategory");
$dimensionFilter->setOperator("EXACT");
$dimensionFilter->setExpressions(array("video"));
// Create the DimensionFilterClauses
$dimensionFilterClause = new
Google_Service_AnalyticsReporting_DimensionFilterClause();
$dimensionFilterClause->setFilters(array($dimensionFilter));
$request->setDimensionFilterClauses(array($dimensionFilterClause));
以下代码应该能够按 EXACT eventCategory 进行过滤,但它不起作用。它 returns 所有事件都可用,当然有点乱。
/*
this querystring is what I'd like to receive, I've built it with the query explorer: https://ga-dev-tools.appspot.com/query-explorer/
ids=ga:private&
start-date=2017-05-01&
end-date=yesterday&
metrics=ga:eventValue,ga:avgEventValue&
dimensions=ga:subContinent,ga:eventCategory,ga:eventAction,ga:eventLabel&
filters=ga:eventCategory==video
*/
// Create the DateRange object.
$dateRange = new Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate("3daysago");
$dateRange->setEndDate("today");
// Create the Metrics object.
$ev = new Google_Service_AnalyticsReporting_Metric();
$ev->setExpression("ga:eventValue");
$ev->setAlias("EventValue");
$avg = new Google_Service_AnalyticsReporting_Metric();
$avg->setExpression("ga:avgEventValue");
$avg->setAlias("Avg Value");
//Create the dimensions
$sc = new Google_Service_AnalyticsReporting_Dimension();
$sc->setName("ga:subContinent");
$ec = new Google_Service_AnalyticsReporting_Dimension();
$ec->setName("ga:eventCategory");
$ea = new Google_Service_AnalyticsReporting_Dimension();
$ea->setName("ga:eventAction");
$el = new Google_Service_AnalyticsReporting_Dimension();
$el->setName("ga:eventLabel");
// Create the segment dimension.
$segmentDimensions = new Google_Service_AnalyticsReporting_Dimension();
$segmentDimensions->setName("ga:segment");
// Create Dimension Filter.
$dimensionFilter = new Google_Service_AnalyticsReporting_SegmentDimensionFilter();
$dimensionFilter->setDimensionName("ga:eventCategory");
$dimensionFilter->setOperator("EXACT");
$dimensionFilter->setExpressions(array("video"));
// Create Segment Filter Clause.
$segmentFilterClause = new Google_Service_AnalyticsReporting_SegmentFilterClause();
$segmentFilterClause->setDimensionFilter($dimensionFilter);
// Create the Or Filters for Segment.
$orFiltersForSegment = new Google_Service_AnalyticsReporting_OrFiltersForSegment();
$orFiltersForSegment->setSegmentFilterClauses(array($segmentFilterClause));
// Create the Simple Segment.
$simpleSegment = new Google_Service_AnalyticsReporting_SimpleSegment();
$simpleSegment->setOrFiltersForSegment(array($orFiltersForSegment));
// Create the Segment Filters.
$segmentFilter = new Google_Service_AnalyticsReporting_SegmentFilter();
$segmentFilter->setSimpleSegment($simpleSegment);
// Create the Segment Definition.
$segmentDefinition = new Google_Service_AnalyticsReporting_SegmentDefinition();
$segmentDefinition->setSegmentFilters(array($segmentFilter));
// Create the Dynamic Segment.
$dynamicSegment = new Google_Service_AnalyticsReporting_DynamicSegment();
$dynamicSegment->setSessionSegment($segmentDefinition);
$dynamicSegment->setName("video buffering");
// Create the Segments object.
$segment = new Google_Service_AnalyticsReporting_Segment();
$segment->setDynamicSegment($dynamicSegment);
// Create the ReportRequest object.
$request = new Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId(VIEW_ID);
$request->setDateRanges(array($dateRange));
$request->setSegments(array($segment));
$request->setDimensions(array($segmentDimensions,$sc,$ec,$ea,$el));
$request->setMetrics(array($ev, $avg));
// Create the GetReportsRequest object.
$getReport = new Google_Service_AnalyticsReporting_GetReportsRequest();
$getReport->setReportRequests(array($request));
// Call the batchGet method.
$body = new Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$response = $analyticsreporting->reports->batchGet( $body );
print_r($response);die;
根据当前请求,我得到的是:
Uncaught Google_Service_Exception: {
"error": {
"code": 400,
"message": "Invalid JSON payload received. Unknown name \"name\" at 'report_requests[0].dimensions[1]': Proto field is not repeating, cannot start list.",
"errors": [
{
"message": "Invalid JSON payload received. Unknown name \"name\" at 'report_requests[0].dimensions[1]': Proto field is not repeating, cannot start list.",
"domain": "global",
"reason": "badRequest"
}
],
"status": "INVALID_ARGUMENT"
}
}
这是我希望收到的经过编辑的数据子集:https://pastebin.com/L1pRgbn4
我知道这对聚会来说真的很晚,但我想也许它可以帮助其他人...我认为这是因为根据您的代码,您正在寻找一个片段,而不是一个过滤器。
There's a key difference between the two:
Segment – 对于一个segment,每次访问都会检查是否满足segment的条件。对于满足条件的会话,返回所有行。对于没有返回的会话,不会返回任何行。
Filter – 对于一个过滤器,考虑了ALL访问的所有行,然后只返回满足过滤器条件的行.
为了很好地回答您的问题 -
简而言之,您可能需要这样的东西:
// Create Dimension Filter.
$dimensionFilter = new
Google_Service_AnalyticsReporting_SegmentDimensionFilter();
$dimensionFilter->setDimensionName("ga:eventCategory");
$dimensionFilter->setOperator("EXACT");
$dimensionFilter->setExpressions(array("video"));
// Create the DimensionFilterClauses
$dimensionFilterClause = new
Google_Service_AnalyticsReporting_DimensionFilterClause();
$dimensionFilterClause->setFilters(array($dimensionFilter));
$request->setDimensionFilterClauses(array($dimensionFilterClause));