Как получить данные отчета Google Analytics, используя v3 их API .NET? - PullRequest
11 голосов
/ 25 января 2012

Я пытался получить аналитические отчеты Google, используя предоставленный API-интерфейс .NET, и действительно ломал голову над тем, как на самом деле получить что-либо с использованием новейшей версии 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:visits&start-date=2011-12-25

Я могу нормально возвращать отчеты, используя версию 2, которая использует GData, но надеяласьчтобы запустить версию 3 в случае, если версия 2 устарела, но из-за большого количества трудностей, связанных с осмысленной документацией, она устарела или не существует, и я не смог найти никаких примеров.

Ответы [ 5 ]

3 голосов
/ 08 мая 2013

Теперь это возможно и просто сделать с последней версией .NET API ( v1.3.0.15233 ). Хотя этот пример не выпущен, но вы можете использовать Образец задания в качестве шаблона для запроса данных GA.

Вот что вам нужно добавить / изменить, чтобы этот пример проекта работал для GA.

Объявление экземпляра AnalyticsService

private static AnalyticsService _analyticsService;

Изменить область действия на Scopes.Analytics

В методе GetAuthorization объявлена ​​переменная scope. Измените его с

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.

3 голосов
/ 28 сентября 2013

После нескольких дней поиска получите доступ к Analitycs, это фреймворк консольного проекта 3.5.

* Если у вас есть проект консоли API Google с активированной службой Google Analytics.
* В Simple API Access необходимо сгенерировать новый ключ для Client 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);
    }

Надеюсь, это поможет.

2 голосов
/ 10 октября 2013

Я разместил пошаговые инструкции о том, как это сделать, здесь: Google V3 Beta API How To

1 голос
/ 13 декабря 2016

Дополнительный полный пример с учетной записью службы.

Установите пакет 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();
        }

    }
}
0 голосов
/ 15 июня 2012

Мы только что обновили нашу аналитическую службу, чтобы использовать v3.0 API, поскольку v2.3 устарела, в google https://developers.google.com/analytics/resources/articles/gdata-migration-guide есть руководство по миграции, которое может помочь.

Я попытался использовать google dotnet API http://code.google.com/p/google-api-dotnet-client/, который поддерживает v3, но сдался, так как не хватает документации и примеров.Мы вызываем API через net.httpwebrequest, что было проще, чем пытаться понять, что происходит в API.

Для версии 3 ваш вызов должен быть 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

...