在过去的条目中,我想出了如何检索特定个人资料ID的指标数据: Exception thrown when using GData .NET Analytics API
现在,我想检索一个与Google Analytics帐户列表中已注册域名相匹配的个人资料ID,这在以前很容易,但在上次Google升级到Management / Core Reporting API 3.0之后,旧的2.3 Feed已关闭且AccountsFeed相关代码未按预期工作。
答案 0 :(得分:1)
使用此处发布的建议:http://code.google.com/p/gdata-issues/issues/detail?can=2&start=0&num=100&q=&colspec=API%20ID%20Type%20Status%20Priority%20Stars%20Summary&groupby=&sort=&id=2955,我想出了这段代码可以完成我需要的工作:
Imports Google
Imports Google.Analytics
Imports Google.GData.Analytics
Imports System.Collections.Generic
Imports System.Collections
Public Function GetProfileId(ByVal DomainText As String) As String
Dim Ids As String = String.Empty
Dim service As GData.Analytics.AnalyticsService = New GData.Analytics.AnalyticsService("MyAnalyticsService")
service.setUserCredentials(username, pass)
//Dim factory As GData.Client.GDataGAuthRequestFactory = CType(service.RequestFactory, GData.Client.GDataGAuthRequestFactory)
//factory.AccountType = "GOOGLE"
//factory.UseSSL = True
//service.RequestFactory = factory
Dim aF As DataFeed = service.Query(New DataQuery("https://www.googleapis.com/analytics/v2.4/management/accounts"))
Dim webPropsUrl As String = ""
For Each o As GData.Client.AtomEntry In aF.Entries
//webproperties
If o.Title.Text.Contains(DomainText) Then
webPropsUrl = o.Links.Item(1).HRef.Content
Exit For
End If
Next
Dim wpF As DataFeed = service.Query(New DataQuery(webPropsUrl))
Dim profileFeedUrl As String = ""
For Each entry As DataEntry In wpF.Entries
//profiles
profileFeedUrl = entry.Links.Item(2).HRef.Content
Exit For
Next
Dim prF As DataFeed = service.Query(New DataQuery(profileFeedUrl))
Dim profileUrl As String = ""
For Each profd As DataEntry In prF.Entries
profileUrl = profd.Links.Item(0).HRef.Content
Exit For
Next
Dim profileId As String = ""
profileId = profileUrl.Split("/")(profileUrl.Split("/").Length - 1)
Return profileId
End Function