Php 谷歌分析api v4多指标查询

Php 谷歌分析api v4多指标查询,php,json,google-analytics-firebase,Php,Json,Google Analytics Firebase,我一直在尝试获取所有包含特定id的URL的指标。从这个问题:我看到了查询方法,并尝试了它,而不是面向对象的版本。在查询方法中,代码工作得非常出色,但它只返回最后发送的度量(在本例中,它只返回唯一的页面视图,因为它是最后列出的度量)。我需要返回所有三个的值,而不需要分别点击api三次。这是我的密码: $query = [ "viewId" => $profileId, "dateRanges" => [ "startDate" =

我一直在尝试获取所有包含特定id的URL的指标。从这个问题:我看到了查询方法,并尝试了它,而不是面向对象的版本。在查询方法中,代码工作得非常出色,但它只返回最后发送的度量(在本例中,它只返回唯一的页面视图,因为它是最后列出的度量)。我需要返回所有三个的值,而不需要分别点击api三次。这是我的密码:

$query = [
        "viewId" => $profileId,
        "dateRanges" => [
            "startDate" => "2018-01-25",
            "endDate" => "2018-01-25"
        ],
        "metrics" => [
            "expression" => "ga:pageviews",
            "expression" => "ga:avgTimeOnPage",
            "expression" => "ga:uniquePageviews"
        ],
        "dimensions" => [
            "name" => "ga:pagepath"
        ],
        "dimensionFilterClauses" => [
            'filters' => [
                "dimension_name" => "ga:pagepath",
                "operator" => "PARTIAL", 
                "expressions" => $theId
            ]
        ]
    ];

    // build the request and response
    $body = new Google_Service_AnalyticsReporting_GetReportsRequest();
    $body->setReportRequests(array($query));
    $report = $analytics->reports->batchGet($body);

你有没有想过我该如何正确地做到这一点

尝试以下功能,只需用您的ID替换ENTER_ID。这似乎也可以获取所有页面的流量

function segmentRequest(&$analyticsreporting) {

  // Create the DateRange object.
  $dateRange = new Google_Service_AnalyticsReporting_DateRange();
  $dateRange->setStartDate("2018-02-01");
  $dateRange->setEndDate("2018-02-15");

  // Create the Metrics object.
  $pageviews = new Google_Service_AnalyticsReporting_Metric();
  $pageviews->setExpression("ga:pageviews");
  $pageviews->setAlias("pageviews");

  //Create the browser dimension.
  $path = new Google_Service_AnalyticsReporting_Dimension();
  $path->setName("ga:pagePath");

  // 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:pagePath");
  $dimensionFilter->setOperator("PARTIAL");
  $dimensionFilter->setExpressions(array("ENTER_ID"));

  // 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("Visits to /en/listings.php");

  // 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("XXXXX");
  $request->setDateRanges(array($dateRange));
  $request->setDimensions(array($path, $segmentDimensions));
  $request->setSegments(array($segment));
  $request->setMetrics(array($pageviews));

  // 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 );

  printResults($response->getReports());
}

对于那些希望继续使用数组构建查询的人,这应该可以:

$request = [
    "viewId" => "123456789",
    "dateRanges" => [
        "startDate" => "2018-01-01",
        "endDate" => "today"
    ],
    "metrics" => [
        "expression" => "ga:pageviews"
    ],
    "dimensions" => [
        ["name" => "ga:browser"],
        ["name" => "ga:sessionDurationBucket"]
    ],
    "dimensionFilterClauses" => [
        'filters' => [
            "dimension_name" => "ga:pagepath",
            "operator" => "EXACT",
            "expressions" => $url
        ]
    ]
];

通过为每个表达式使用一个数组(
[“expression”=>“ga:uniquePageviews”]
),可以以数组样式定义多个度量


不知道答案是什么,但这是非常感谢张贴你的例子。非常有帮助!事实上,我最终选择了这种样式来实现api,而不是上面的数组样式。但是,上面提到的糟糕透顶的东西是不起作用的——它看起来太干净了!同意,他们的OOP风格的方法是sh*t(说得委婉些)
  $query = [
          "viewId" => profileId,
          "dateRanges" => [
              "startDate" => "2018-01-25",
              "endDate" => "2018-01-25"
          ],
          "metrics" => [
              ["expression" => "ga:pageviews"],
              ["expression" => "ga:avgTimeOnPage"],
              ["expression" => "ga:uniquePageviews"]               
              
          ],
          "dimensions" => [
              "name" => "ga:pagepath"
          ],
    ];