データアクセス レポート

データアクセス レポートは、Admin API v1 の runAccessReport メソッドを使用して作成できます。このレポートには、ユーザーが Google アナリティクスのデータを読み取るたびに表示されます。データアクセス レコードは最長 2 年間保持されます。データアクセス レポートは、管理者の役割を持つユーザーのみが利用できます。

クライアント ライブラリを使用してデータアクセス レポートをリクエストする

データアクセス レポートをすぐに使用するには、クライアント ライブラリを使用します。

Google アナリティクス クライアント ライブラリのインストールと設定方法については、クイック スタートガイドをご覧ください。

以下は、データアクセス クエリを実行してレスポンスを出力する Python クライアント ライブラリの使用例です。

Python

from datetime import datetime

from google.analytics.admin import AnalyticsAdminServiceClient
from google.analytics.admin_v1alpha.types import (
    AccessDateRange,
    AccessDimension,
    AccessMetric,
    RunAccessReportRequest,
)


def run_sample():
    """Runs the sample."""
    # TODO(developer): Replace this variable with your Google Analytics 4
    #  property ID (e.g. "123456") before running the sample.
    property_id = "YOUR-GA4-PROPERTY-ID"
    run_access_report(property_id)


def run_access_report(property_id: str, transport: str = None):
    """
    Runs an access report for a Google Analytics property. The report will
    aggregate over dimensions `userEmail`, `accessedPropertyId`,
    `reportType`, `revenueDataReturned`, `costDataReturned`,
    `userIP`, and return the access count, as well as the most recent access
    time for each combination.
    See https://developers.google.com/analytics/devguides/config/admin/v1/access-api-schema
    for the description of each field used in a data access report query.
    Args:
        property_id(str): The Google Analytics Property ID.
        transport(str): The transport to use. For example, "grpc"
            or "rest". If set to None, a transport is chosen automatically.
    """
    client = AnalyticsAdminServiceClient(transport=transport)
    request = RunAccessReportRequest(
        entity=f"properties/{property_id}",
        dimensions=[
            AccessDimension(dimension_name="userEmail"),
            AccessDimension(dimension_name="accessedPropertyId"),
            AccessDimension(dimension_name="reportType"),
            AccessDimension(dimension_name="revenueDataReturned"),
            AccessDimension(dimension_name="costDataReturned"),
            AccessDimension(dimension_name="userIP"),
            AccessDimension(dimension_name="mostRecentAccessEpochTimeMicros"),
        ],
        metrics=[AccessMetric(metric_name="accessCount")],
        date_ranges=[AccessDateRange(start_date="yesterday", end_date="today")],
    )

    access_report = client.run_access_report(request)

    print("Result:")
    print_access_report(access_report)


def print_access_report(response):
    """Prints the access report."""
    print(f"{response.row_count} rows received")
    for dimensionHeader in response.dimension_headers:
        print(f"Dimension header name: {dimensionHeader.dimension_name}")
    for metricHeader in response.metric_headers:
        print(f"Metric header name: {metricHeader.metric_name})")

    for rowIdx, row in enumerate(response.rows):
        print(f"\nRow {rowIdx}")
        for i, dimension_value in enumerate(row.dimension_values):
            dimension_name = response.dimension_headers[i].dimension_name
            if dimension_name.endswith("Micros"):
                # Convert microseconds since Unix Epoch to datetime object.
                dimension_value_formatted = datetime.utcfromtimestamp(
                    int(dimension_value.value) / 1000000
                )
            else:
                dimension_value_formatted = dimension_value.value
            print(f"{dimension_name}: {dimension_value_formatted}")

        for i, metric_value in enumerate(row.metric_values):
            metric_name = response.metric_headers[i].metric_name
            print(f"{metric_name}: {metric_value.value}")

コア レポートと共有される機能

データアクセス レポート リクエストは、多くの一般的な機能でコア レポート リクエストと同じセマンティクスを持ちます。たとえば、ページネーションディメンション フィルタ期間は、どちらのレポートタイプでも同じ動作をします。

Data API v1 のコア レポートの概要を理解したら、このページに戻ってデータアクセス レポートの詳細を確認してください。

データアクセス レポートを作成する

runAccessReport メソッドを使用して、データアクセス レポートをリクエストします。

レポート対象エンティティを選択する

Data API v1 のコア レポート機能と同様に、Google アナリティクス Admin API v1 の runAccessReport メソッドでは、URL リクエスト パス内に properties/GA_PROPERTY_ID の形式でGoogle アナリティクス プロパティ ID を指定する必要があります。次に例を示します。

  POST  https://analyticsadmin.googleapis.com/v1beta/properties/GA_PROPERTY_ID:runAccessReport

生成されるデータアクセス レポートは、指定した Google アナリティクス プロパティの Google アナリティクスのデータアクセス レコードに基づいて生成されます。

Admin API クライアント ライブラリのいずれかを使用している場合は、リクエスト URL パスを手動で操作する必要はありません。ほとんどの API クライアントでは、文字列が properties/GA_PROPERTY_ID の形式の property パラメータが提供されています。クライアント ライブラリの使用例については、このページの上部にあるコード スニペットをご覧ください。

ディメンションと指標を選択する

ディメンションは、プロパティのアクセス データを記述してグループ化します。たとえば、ディメンション userEmail は、レポートデータにアクセスしたユーザーのメールアドレスを示します。レポート レスポンスのディメンション値は文字列です。

指標は、レポートの定量的な測定値を表します。accessCount 指標は、データアクセス レコードの合計数を返します。

データアクセス レポート リクエストで使用できるディメンション名と指標名の一覧については、データアクセス スキーマをご覧ください。

レポートをリクエストする

データアクセス レポートをリクエストするには、RunAccessReportRequest オブジェクトを作成します。最初は、次のリクエスト パラメータを使用することをおすすめします。

  • [日付範囲] フィールドに有効なエントリが 1 つ以上ある。
  • dimensions フィールドに有効なエントリが 1 つ以上ある。
  • epochTimeMicros ディメンションを使用しない場合は、レポート内のディメンション値の組み合わせごとに定量データを受け取る指標フィールドに有効なエントリが 1 つ以上必要です。

推奨されるフィールドを含むリクエストの例を次に示します。このクエリは、ユーザーのメールアドレス、過去 7 日間の期間に指定された宿泊施設にアクセスした最新の日時、対応するアクセス数のリストを生成します。

HTTP

POST https://analyticsadmin.googleapis.com/v1beta/properties/GA_PROPERTY_ID:runAccessReport
{
  "dateRanges": [
    {
      "startDate": "7daysAgo",
      "endDate": "today"
    }
  ],
  "dimensions": [
    {
      "dimensionName": "mostRecentAccessEpochTimeMicros"
    },
    {
      "dimensionName": "userEmail"
    }
  ],
  "metrics": [
    {
      "metricName": "accessCount"
    }
  ]
}

回答を読み上げる

データアクセス レポートのレスポンスは、主にヘッダーと行で構成されます。ヘッダーは、レポート内の列を一覧表示する AccessDimensionHeadersAccessMetricHeaders で構成されます。

アクセス レポートの行は、レポートの列の AccessDimensionValuesAccessMetricValues で構成されます。列の順序は、リクエスト、ヘッダー、すべての行で一貫しています。

上記のサンプル リクエストに対するレスポンスの例を次に示します。

{
  "dimensionHeaders": [
    {
      "dimensionName": "mostRecentAccessEpochTimeMicros"
    },
    {
      "dimensionName": "userEmail"
    }
  ],
  "metricHeaders": [
    {
      "metricName": "accessCount"
    }
  ],
  "rows": [
    {
      "dimensionValues": [
        {
          "value": "1667591408427733"
        },
        {
          "value": "Bola@example.net"
        }
      ],
      "metricValues": [
        {
          "value": "1238"
        }
      ]
    },
    {
      "dimensionValues": [
        {
          "value": "1667710959827161"
        },
        {
          "value": "Alex@example.net"
        }
      ],
      "metricValues": [
        {
          "value": "475"
        }
      ]
    },
    {
      "dimensionValues": [
        {
          "value": "1667868650762743"
        },
        {
          "value": "Mahan@example.net"
        }
      ],
      "metricValues": [
        {
          "value": "96"
        }
      ]
    }
  ],
  "rowCount": 3
}

アクセス レコードでフィルタする

RunAccessReportRequest オブジェクトの dimensionFilter フィールドを使用して、レポートのレスポンスを、フィルタに一致する特定のディメンション値に制限します。

次の例では、個々のデータアクセス レコードに基づいてレポートを生成し、メールアドレスが Alex@example.net の単一ユーザーのアクセス レコードでフィルタします。レポートには、各アクセス レコードの時間、ユーザーのメールアドレス、IP アドレスが含まれます。

HTTP

POST https://analyticsadmin.googleapis.com/v1beta/properties/GA_PROPERTY_ID:runAccessReport
{
  "dateRanges": [
    {
      "startDate": "7daysAgo",
      "endDate": "today"
    }
  ],
  "dimensions": [
    {
      "dimensionName": "epochTimeMicros"
    },
    {
      "dimensionName": "userEmail"
    },
    {
      "dimensionName": "userIP"
    }
  ],
  "dimensionFilter": {
    "accessFilter": {
      "fieldName": "userEmail",
      "stringFilter": {
        "matchType": "EXACT",
        "value": "Alex@example.net"
      }
    }
  }
}

同様に、RunAccessReportRequest オブジェクトの metricFilter フィールドを使用して、レポートのレスポンスをフィルタに一致する特定の指標値に制限できます。

次の例では、指定したプロパティに 100 回以上アクセスしたすべてのユーザーのメールアドレスとアクセス回数を含むレポートを生成します。

HTTP

{
  "dateRanges": [
    {
      "startDate": "7daysAgo",
      "endDate": "today"
    }
  ],
  "dimensions": [
    {
      "dimensionName": "userEmail"
    }
  ],
  "metricFilter": {
    "accessFilter": {
      "numericFilter": {
        "operation": "GREATER_THAN",
        "value": {
          "int64Value": 100
        }
      },
      "fieldName": "accessCount"
    }
  },
  "metrics": [
    {
      "metricName": "accessCount"
    }
  ]
}

サンプル レポート

試すことができるサンプル レポートをいくつかご紹介します。

最近のアクセス

runAccessReport を使用して作成できるアクセス レポートのサンプル:

最新アクセスの Unix エポックタイム(マイクロ秒) ユーザーのメール アクセス数
1525220215025371 Bola@example.net 5
1525220215028361 Alex@example.net 36
1525220215027671 Charlie@example.net 1153
1525220215027341 Mahan@example.net 1

このレポートは、ディメンション mostRecentAccessEpochTimeMicrosuserEmailaccessCount 指標をクエリすることで生成できます。レポートには、ユーザーごとに 1 行が含まれます。mostRecentAccessEpochTimeMicros ディメンションは、プロパティにアクセスしたユーザーごとにデータアクセス レコードを集計し、各行の最終アクセス時間(エポックからの Unix マイクロ秒数)を返します。

ユーザー アクセスの内訳

役立つレポートの例として、アクセス メカニズム(Google アナリティクスのユーザー インターフェース、API など)別のユーザーアクセスの内訳も挙げられます。

最新アクセスの Unix エポックタイム(マイクロ秒) ユーザーのメール アクセス メカニズム アクセス数
1525220215028367 Alex@example.net Firebase 31
1525220215555778 Alex@example.net Google アナリティクスのユーザー インターフェース 1
1525220215022378 Bola@example.net Google アナリティクスのユーザー インターフェース 65
1525220215026389 Bola@example.net Google Analytics API 894
1525220215025631 Charlie@example.net Google Analytics API 67
1525220215068325 Mahan@example.net Google 広告 3

このレポートは、ディメンション mostRecentAccessEpochTimeMicrosuserEmailaccessMechanism、および accessCount 指標をクエリすることで生成できます。

レポートには、ユーザーとアクセス メカニズムの組み合わせごとに 1 行が含まれます。mostRecentAccessEpochTimeMicros ディメンションには、指定されたアクセス メカニズムを使用してユーザーが最後にプロパティにアクセスした日時が含まれます。

プロパティ アクセスの概要

個々のユーザーを分類せずに、プロパティのレポートを生成できます。たとえば、次のレポートは、さまざまなアクセス メカニズムを使用してプロパティにアクセスされた頻度を示しています。

アクセスしたプロパティ ID アクセスしたプロパティ名 アクセス メカニズム アクセス数
12345678 DemoApp Firebase 31
12345678 DemoApp Google アナリティクスのユーザー インターフェース 624
12345678 DemoApp Google 広告 83
12345678 DemoApp Google Analytics API 1744

このレポートは、ディメンション accessedPropertyIdaccessedPropertyNameaccessMechanism、および accessCount 指標をクエリすることで生成できます。

レポートには、プロパティ ID とアクセス メカニズムの組み合わせごとに 1 行が含まれます。

個々のデータへのアクセス

各行が個々のデータアクセス レコードに基づくレポートを生成するには、クエリから mostRecentAccessEpochTimeMicros ディメンションを省略し、代わりに epochTimeMicros ディメンションを使用してください。レポートのすべての行に、単一のデータアクセスの発生に関する情報が含まれているため、accessCount 指標をクエリする必要はありません。

次のレポートには、ユーザーが指定されたプロパティにアクセスした各回に関する詳細情報が含まれます。

Unix エポック時間(マイクロ秒) ユーザーのメール アクセスしたプロパティ ID アクセスしたプロパティ名 ユーザー IP アクセス メカニズム 返された費用データ 返された収益データ
1525220215025371 Bola@example.net 12345678 DemoApp 1.2.3.1 Google アナリティクスのユーザー インターフェース true true
1525220645645645 Mahan@example.net 12345678 DemoApp 1.2.3.5 Google アナリティクスのユーザー インターフェース false false
1525220211312322 Bola@example.net 12345678 DemoApp 11.22.33.11 Google 広告 true false
1525220210234221 Alex@example.net 12345678 DemoApp 11.22.33.22 Firebase false false
1525220215028368 Alex@example.net 12345678 DemoApp 1.2.3.2 Google 広告 false false
1525220214234231 Mahan@example.net 12345678 DemoApp 11.22.33.55 Google 広告 true true
1525220423423452 Charlie@example.net 12345678 DemoApp 1.2.3.3 Google Analytics API true false
1525220132312333 Mahan@example.net 12345678 DemoApp 1.2.3.5 Google 広告 true true

このレポートは、ディメンション epochTimeMicrosuserEmailaccessedPropertyIdaccessedPropertyNameuserIPaccessMechanismcostDataReturnedrevenueDataReturned をクエリすることで生成できます。