11

我一直在尝试使用他们提供的 .NET api 检索 Google 分析报告,并且一直在摸索我如何使用最新版本 v3 实际检索任何内容,该版本可在此处获得:http ://code.google.com /apis/analytics/docs/gdata/v3/gdataLibraries.html

例如,我想检索这样一个报告查询: https ://www.google.com/analytics/feeds/data?dimensions=ga:browser&end-date=2012-01-25&ids=ga:ACCOUNTID&metrics= ga:访问&开始日期=2011-12-25

我能够使用使用 GData 的版本 2 很好地返回报告,但希望在版本 2 被弃用的情况下让版本 3 继续运行,但是在看到有意义的文档似乎已经过时或不存在时遇到了很多麻烦和我找不到任何例子。

4

5 回答 5

3

现在可以使用最新版本的 .NET API ( v1.3.0.15233 ) 轻松实现这一点。虽然没有发布示例,但您可以使用Task 示例作为模式来查询 GA 数据。

这是您需要添加/更改以使该示例项目适用于 GA 的内容。

声明一个实例AnalyticsService

private static AnalyticsService _analyticsService;

将范围更改为Scopes.Analytics

scope方法内部声明了一个变量GetAuthorization。改变它从

string scope = TasksService.Scopes.TasksReadonly.GetStringValue();

string scope = AnalyticsService.Scopes.Analytics.GetStringValue();

初始化您的 GA 服务

if (_analyticsService == null)
{
    _analyticsService = new AnalyticsService(new BaseClientService.Initializer()
    {
        Authenticator = _authenticator = CreateAuthenticator();  
    });
}

进行查询

这是查询 GA 配置文件的方式

// make a request
var request = _analyticsService.Data.Ga.Get(
    "ga:12345678", 
    "2013-01-01",
    "2013-05-08", 
    "ga:visits,ga:bounces,ga:timeOnSite,ga:avgTimeOnSite");
// run the request and get the data                
var data = request.Fetch();

GetRequest您会注意到,与 API Doc 中定义的类似,有四个必需的参数。您可以访问查询资源管理器以了解与 .NET API 一起使用的有效指标。

于 2013-05-08T10:18:58.950 回答
3

经过几天的搜索实现访问Anaalitycs,是一个控制台项目框架3.5。

* 您必须有一个激活了 Analytics API 服务的 google API 控制台项目。
* 在简单 API 访问中,必须为已安装应用程序的客户端 ID 生成新密钥。
* 下载并添加对 Google.Apis.Analytics.v3.dll 的引用
* 下载并添加对 Google.Apis.Authentication.OAuth2.dll 的引用
* 下载并添加对 Google.Apis.dll 的引用
* 下载并添加对 Newtonsoft.Json 的引用.Net35.dll
* 下载并添加对 DotNetOpenAuth.dll 的引用

最后实现以下代码:

private const string Scope = "https://www.googleapis.com/auth/analytics.readonly";
    static void Main(string[] args)
    {
        try
        {
            var provider = new NativeApplicationClient(GoogleAuthenticationServer.Description);
            provider.ClientIdentifier = "Your_Client_ID";
            provider.ClientSecret = "Your_Client_Secret";
            var auth = new OAuth2Authenticator<NativeApplicationClient>(provider, GetAuthentication);
            var asv = new AnalyticsService(auth);
            var request = asv.Data.Ga.Get("ga:Your_TrackingID", "2013-08-05", "2013-08-05", "ga:visitors");
            request.Dimensions = "ga:visitorType";
            var report = request.Fetch();
            var rows = report.Rows;
            var newVisitors = rows[0];
            var returnVisitors = rows[1];
            Console.WriteLine(newVisitors[0] + ": " + newVisitors[1]);
            Console.WriteLine(returnVisitors[0] + ": " + returnVisitors[1]);
            int newV = Int32.Parse(newVisitors[1]);
            int retV = Int32.Parse(returnVisitors[1]);
            int sum = newV + retV;
            Console.WriteLine("Total:  " + sum);
        }

        catch(Exception ex){
            Console.WriteLine("\n Error: \n" + ex);
            Console.ReadLine();
        }

    }

private static IAuthorizationState GetAuthentication(NativeApplicationClient arg)
    {
        IAuthorizationState state = new AuthorizationState(new[] { Scope });
        state.Callback = new Uri(NativeApplicationClient.OutOfBandCallbackUrl);
        Uri authUri = arg.RequestUserAuthorization(state);
        System.Diagnostics.Process.Start(authUri.ToString());
        Console.Write("Paste authorization code: ");
        string authCode = Console.ReadLine();
        return arg.ProcessUserAuthorization(authCode, state);
    }

希望这可以帮助。

于 2013-09-27T23:09:37.670 回答
2

我在此处发布了有关如何执行此操作的分步说明:Google V3 Beta API How To

于 2013-10-10T15:33:59.013 回答
1

服务帐户的附加完整示例。

安装 nuget 包 Google.Apis.Analytics.v3。

//based on https://github.com/LindaLawton/Google-Dotnet-Samples/tree/master/Google-Analytics

using System;
using System.Threading.Tasks;

using System.Security.Cryptography.X509Certificates;
using Google.Apis.Analytics.v3;
using Google.Apis.Analytics.v3.Data;
using Google.Apis.Auth.OAuth2;
using Google.Apis.Util;
using System.Collections.Generic;
using Google.Apis.Services;

namespace GAImport
{


    class Program
    {
        static void Main(string[] args)
        {
            string[] scopes = new string[] { AnalyticsService.Scope.AnalyticsReadonly }; 

            var keyFilePath = @"path\to\key.p12";    
            var serviceAccountEmail = "someuser@....gserviceaccount.com";  

            //loading the Key file
            var certificate = new X509Certificate2(keyFilePath, "notasecret", X509KeyStorageFlags.Exportable);
            var credential = new ServiceAccountCredential(new ServiceAccountCredential.Initializer(serviceAccountEmail)
            {
                Scopes = scopes
            }.FromCertificate(certificate));
            var service = new AnalyticsService(new BaseClientService.Initializer()
            {
                HttpClientInitializer = credential,
                ApplicationName = "Analytics API Sample",
            });
            var request = service.Data.Ga.Get("ga:1234567", "30daysAgo", "yesterday", "ga:sessions");
            request.MaxResults = 1000;
            var result = request.Execute();
            foreach (var headers in result.ColumnHeaders)
            {
                Console.WriteLine(String.Format("{0} - {1} - {2}", headers.Name, headers.ColumnType, headers.DataType));
            }

            foreach (List<string> row in result.Rows)
            {
                foreach (string col in row)
                {
                    Console.Write(col + " "); 
                }
                Console.Write("\r\n");

            }


            Console.ReadLine();
        }

    }
}
于 2016-12-13T09:53:39.120 回答
0

我们刚刚更新了我们的分析服务以使用 API 的 v3.0,因为现在不推荐使用 v2.3,谷歌上有一个迁移指南https://developers.google.com/analytics/resources/articles/gdata-migration -指导可能有帮助的指南。

我尝试使用谷歌 dotnet API http://code.google.com/p/google-api-dotnet-client/但由于缺乏文档和示例而放弃了。我们通过 net.httpwebrequest 调用 api,这比试图弄清楚 API 中发生的事情更容易。

对于 v3,您的电话应该是 https://www.googleapis.com/analytics/v3/data/ga?dimensions=ga:browser&end-date=2012-01-25&ids=ga:ACCOUNTID&metrics=ga:visits&start-date=2011 -12-25

于 2012-06-15T07:42:49.140 回答