目次

Web検索はbingがおすすめ!

Google Analytics から複数の値(PV,UU)を取得する - C#

Google Analytics Data Export APIを用いてGoogle Analyticsの複数の値(今回は、ページビュー数と訪問者数)を日別で取得します。
サービス終了に関する注意
Google Universal Analytics はサービスを終了したため、現在はこの記事で紹介しているコードは動作しません。 新しい Google Analytics 4 (GA4) プロパティを利用する必要があります。 GA4プロパティからのデータ取得はこちらの記事を参照してください。

UI

こちらの記事のUIと同じものを用います。

コード

ボタンのClickイベントに下記コードを記述します。
private void button_PVUU_Click(object sender, EventArgs e)
{
  listView_PageView.Items.Clear();

  string userName = textBox_User.Text;
  string passWord = textBox_Pass.Text;
  if (listView_Profile.SelectedItems == null) {
    return;
  }
  string profileId = listView_Profile.SelectedItems[0].SubItems[1].Text;
  const string dataFeedUrl = "https://www.google.com/analytics/feeds/data";

  AnalyticsService service = new AnalyticsService("AnalyticsSampleApp(iPentec)");
  if (!string.IsNullOrEmpty(userName)) {
    service.setUserCredentials(userName, passWord);
  }

  DataQuery query = new DataQuery(dataFeedUrl);
  query.Ids = profileId;
  query.Metrics = "ga:pageviews,ga:visitors";
  query.Dimensions = "ga:Date";
  query.Sort = "ga:Date";
  query.GAStartDate = dateTimePicker_Start.Value.ToString("yyyy-MM-dd");
  query.GAEndDate = dateTimePicker_End.Value.ToString("yyyy-MM-dd");
  query.NumberToRetrieve = 500;

  DataFeed dataFeed = service.Query(query);
  foreach (DataEntry entry in dataFeed.Entries) {
    ListViewItem item = new ListViewItem(entry.Title.Text);
    item.SubItems.Add(entry.Metrics[0].Value);
    item.SubItems.Add(entry.Metrics[1].Value);
    listView_PageView.Items.Add(item);
  }
}

解説

query.Metrics = "ga:pageviews,ga:visitors";
を指定することで、ページビュー数と訪問者数の値を取得します。

query.Dimensions = "ga:Date";
を指定することで、日別で値を集計します。

query.GAStartDate = dateTimePicker_Start.Value.ToString("yyyy-MM-dd");
query.GAEndDate = dateTimePicker_End.Value.ToString("yyyy-MM-dd");
には集計の期間を指定します。
上記のクエリ設定により、指定した期間の日別のPV数を取得できます。

query.Sort = "ga:Date";
を指定しているため、並び順は日付順(昇順)になります。

複数値がある場合は、DataEntryのMetrics[0]に最初の値が、Metrics[1」に2番目の値が入っています。値の順番はquery.Metricsで指定した順番と同じになります。

実行結果

Metrics[0]列にPVがMetrics[1]列にUUが表示されます。ソート順は日付です。


著者
iPentecのメインプログラマー
C#, ASP.NET の開発がメイン、少し前まではDelphiを愛用
掲載日: 2011-11-28
iPentec all rights reserverd.