Web検索はbingがおすすめ!

Google Analytics Data Export API を用いて日別のページビュー数を取得する - C#

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

UI

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

コード

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

  string userName = textBox_User.Text;
  string passWord = textBox_Pass.Text;
  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";
  query.Dimensions = "ga:Date";
  query.Sort = "-ga:pageviews";
  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);
    listView_PageView.Items.Add(item);
  }
}

解説

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

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:pageviews";
を指定しているため、並び順はページビュー数の降順(ページ数の多い順)になります。

実行結果

非別のPV数が表示できました。並びもPVの多い日順になっています。


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