En este documento, se describen varias funciones avanzadas de la API de datos de Google Analytics v1. Para obtener una referencia detallada de la API, consulta la Referencia de la API.
Cómo enumerar definiciones personalizadas y crear informes
La API de datos puede crear informes sobre las dimensiones personalizadas y las métricas personalizadas registradas. El método de la API de metadatos se puede usar para enumerar los nombres de las APIs de las definiciones personalizadas registradas de tu propiedad. Estos nombres de API se pueden usar, por ejemplo, en solicitudes de informes al método runReport.
En las siguientes secciones, se muestran ejemplos de cada tipo de definición personalizada. En estos ejemplos, reemplaza GA_PROPERTY_ID
por tu ID de propiedad.
Dimensiones personalizadas centradas en el evento
Paso 1: Consulta el método de la API de metadatos con el ID de tu propiedad.
GET https://analyticsdata.googleapis.com/v1beta/properties/GA_PROPERTY_ID/metadata
Paso 2: En la respuesta, busca la dimensión personalizada centrada en el evento sobre la que te interesa crear informes. Si la dimensión no está presente, debes registrarla.
"dimensions": [
...
{
"apiName": "customEvent:achievement_id",
"uiName": "Achievement ID",
"description": "An event scoped custom dimension for your Analytics property."
},
...
],
Paso 3: Incluye la dimensión personalizada en una solicitud de informe. La siguiente es una solicitud de muestra al método runReport.
POST https://analyticsdata.googleapis.com/v1beta/properties/GA_PROPERTY_ID:runReport
{
"dateRanges": [{ "startDate": "2020-09-01", "endDate": "2020-09-15" }],
"dimensions": [{ "name": "customEvent:achievement_id" }],
"metrics": [{ "name": "eventCount" }]
}
Dimensiones personalizadas centradas en el usuario
Paso 1: Consulta el método de la API de metadatos con el ID de tu propiedad.
GET https://analyticsdata.googleapis.com/v1beta/properties/GA_PROPERTY_ID/metadata
Paso 2: En la respuesta, busca la dimensión personalizada centrada en el usuario sobre la que te interesa crear informes. Si la dimensión no está presente, debes registrarla.
"dimensions": [
...
{
"apiName": "customUser:last_level",
"uiName": "Last level",
"description": "A user property for your Analytics property."
},
...
],
Paso 3: Incluye la dimensión personalizada en una solicitud de informe. La siguiente es una solicitud de muestra al método runReport.
POST https://analyticsdata.googleapis.com/v1beta/properties/GA_PROPERTY_ID:runReport
{
"entity": { "propertyId": "GA_PROPERTY_ID" },
"dateRanges": [{ "startDate": "7daysAgo", "endDate": "yesterday" }],
"dimensions": [{ "name": "customUser:last_level" }],
"metrics": [{ "name": "activeUsers" }]
}
Métricas personalizadas centradas en el evento
Paso 1: Consulta el método de la API de metadatos con el ID de tu propiedad.
GET https://analyticsdata.googleapis.com/v1beta/properties/GA_PROPERTY_ID/metadata
Paso 2: En la respuesta, busca la métrica personalizada centrada en el evento sobre la que te interesa crear informes. Si la métrica no está presente, debes registrarla.
"metrics": [
...
{
"apiName": "customEvent:credits_spent",
"uiName": "Credits Spent",
"description": "An event scoped custom metric for your Analytics property.",
"type": "TYPE_STANDARD"
},
...
],
Paso 3: Incluye la métrica personalizada en una solicitud de informe. La siguiente es una solicitud de muestra al método runReport.
POST https://analyticsdata.googleapis.com/v1beta/properties/GA_PROPERTY_ID:runReport
{
"dateRanges": [{ "startDate": "30daysAgo", "endDate": "yesterday" }],
"dimensions": [{ "name": "eventName" }],
"metrics": [{ "name": "customEvent:credits_spent" }]
}
Métricas de porcentaje de eventos clave para un evento clave
Paso 1: Consulta el método de la API de metadatos con el ID de tu propiedad.
GET https://analyticsdata.googleapis.com/v1beta/properties/GA_PROPERTY_ID/metadata
Paso 2: En la respuesta, busca la métrica Tasa de porcentaje de eventos clave para un evento clave sobre el que te interese crear informes. Si el evento clave no está presente, debes configurarlo.
"metrics": [
...
{
"apiName": "sessionKeyEventRate:add_to_cart",
"uiName": "Session key event rate for add_to_cart",
"description": "The percentage of sessions in which a specific key event was triggered",
},
...
],
Paso 3: Incluye la métrica Tasa de porcentaje de eventos clave en una solicitud de informe. La siguiente es una solicitud de muestra al método runReport.
POST https://analyticsdata.googleapis.com/v1beta/properties/GA_PROPERTY_ID:runReport
{
"dateRanges": [{ "startDate": "30daysAgo", "endDate": "yesterday" }],
"dimensions": [{ "name": "eventName" }],
"metrics": [{ "name": "sessionKeyEventRate:add_to_cart" }]
}
Promedios de métricas personalizadas centradas en el evento
Paso 1: Consulta el método de la API de metadatos con el ID de tu propiedad.
GET https://analyticsdata.googleapis.com/v1beta/properties/GA_PROPERTY_ID/metadata
Paso 2: En la respuesta, busca el promedio de métricas personalizadas centradas en el evento sobre el que te interesa crear informes. Si la métrica no está presente, debes registrarla.
"metrics": [
...
{
"apiName": "averageCustomEvent:credits_spent",
"uiName": "Average Credits Spent",
"description": "The average of an event scoped custom metric for your Analytics property.",
"type": "TYPE_STANDARD"
},
...
],
Paso 3: Incluye el promedio de la métrica personalizada en una solicitud de informe. La siguiente es una solicitud de muestra al método runReport.
POST https://analyticsdata.googleapis.com/v1beta/properties/GA_PROPERTY_ID:runReport
{
"dateRanges": [{ "startDate": "2020-11-01", "endDate": "2020-11-10" }],
"dimensions": [{ "name": "eventName" }],
"metrics": [{ "name": "averageCustomEvent:credits_spent" }]
}
Ejemplos de informes de cohorte
Los informes de cohortes crean una serie temporal de la retención de usuarios de la cohorte. Para obtener una documentación detallada de cada campo de la API, consulta la referencia de REST para CohortSpec.
Crea un informe de cohorte
Este es un informe de cohorte de muestra en el que se cumple lo siguiente:
- La cohorte son los usuarios con un
firstSessionDate
de2020-12-01
, que configura el objetocohorts
. Las dimensiones y métricas de la respuesta del informe solo se basarán en los usuarios de la cohorte. - El informe de cohorte mostrará tres columnas, que se configuran con los objetos de dimensiones y métricas.
- La dimensión
cohort
es el nombre de la cohorte. - La dimensión
cohortNthDay
es la cantidad de días desde2020-12-01
. - La métrica
cohortActiveUsers
es la cantidad de usuarios que aún están activos.
- La dimensión
- El objeto
cohortsRange
especifica que el informe debe contener datos de eventos que comienzan en2020-12-01
y terminan en2020-12-06
para esta cohorte.- Cuando se usa un nivel de detalle de
DAILY
, se recomienda la dimensióncohortNthDay
para mantener la coherencia.
- Cuando se usa un nivel de detalle de
La solicitud de informe de la cohorte es la siguiente:
POST https://analyticsdata.googleapis.com/v1beta/properties/GA_PROPERTY_ID:runReport
{
"dimensions": [{ "name": "cohort" }, { "name": "cohortNthDay" }],
"metrics": [{ "name": "cohortActiveUsers" }],
"cohortSpec": {
"cohorts": [
{
"dimension": "firstSessionDate",
"dateRange": { "startDate": "2020-12-01", "endDate": "2020-12-01" }
}
],
"cohortsRange": {
"endOffset": 5,
"granularity": "DAILY"
}
},
}
Para esta solicitud, una respuesta de informe de ejemplo es la siguiente:
{
"dimensionHeaders": [
{ "name": "cohort" }, { "name": "cohortNthDay" }
],
"metricHeaders": [
{ "name": "cohortActiveUsers", "type": "TYPE_INTEGER" }
],
"rows": [
{
"dimensionValues": [{ "value": "cohort_0" },{ "value": "0000" }],
"metricValues": [{ "value": "293" }]
},
{
"dimensionValues": [{ "value": "cohort_0" },{ "value": "0001" }],
"metricValues": [{ "value": "143" }]
},
{
"dimensionValues": [{ "value": "cohort_0" },{ "value": "0002" }],
"metricValues": [{ "value": "123" }]
},
{
"dimensionValues": [{ "value": "cohort_0" },{ "value": "0003" }],
"metricValues": [{ "value": "92" }]
},
{
"dimensionValues": [{ "value": "cohort_0" },{ "value": "0005" }],
"metricValues": [{ "value": "86" }]
},
{
"dimensionValues": [{ "value": "cohort_0" },{ "value": "0004" }],
"metricValues": [{ "value": "83" }]
}
],
"metadata": {},
"rowCount": 6
}
Después de esta respuesta, se muestra un gráfico de este informe de cohorte. Una conclusión de este informe es que la mayor disminución en la cantidad de usuarios activos de esta cohorte se produce entre el primer y el segundo día.
Varias cohortes y fracción de retención de usuarios
La adquisición y retención de usuarios son formas de hacer crecer tu sitio web o aplicación. Los informes de cohortes se centran en la retención de usuarios. En este ejemplo, el informe muestra que esta propiedad mejoró su retención de usuarios durante 4 días en un 10% a lo largo de dos semanas.
Para crear este informe, especificamos tres cohortes: la primera con un firstSessionDate
de 2020-11-02
, la segunda con un firstSessionDate
de 2020-11-09
y la tercera con un firstSessionDate
de 2020-11-16
. Debido a que la cantidad de usuarios en tu propiedad será diferente durante estos tres días, comparamos la métrica de fracción de retención de usuarios de la cohorte de cohortActiveUsers/cohortTotalUsers
en lugar de usar la métrica directa de cohortActiveUsers
.
La solicitud de informe para estas cohortes es la siguiente:
POST https://analyticsdata.googleapis.com/v1beta/properties/GA_PROPERTY_ID:runReport
{
"dimensions": [{ "name": "cohort" },{ "name": "cohortNthDay" }],
"metrics": [
{
"name": "cohortRetentionFraction",
"expression": "cohortActiveUsers/cohortTotalUsers"
}
],
"cohortSpec": {
"cohorts": [
{
"dimension": "firstSessionDate",
"dateRange": { "startDate": "2020-11-02", "endDate": "2020-11-02" }
},
{
"dimension": "firstSessionDate",
"dateRange": { "startDate": "2020-11-09", "endDate": "2020-11-09" }
},
{
"dimension": "firstSessionDate",
"dateRange": { "startDate": "2020-11-16", "endDate": "2020-11-16" }
}
],
"cohortsRange": {
"endOffset": 4,
"granularity": "DAILY"
}
},
}
Para esta solicitud, una respuesta de informe de ejemplo es la siguiente:
{
"dimensionHeaders": [{ "name": "cohort" },{ "name": "cohortNthDay" }],
"metricHeaders": [{
"name": "cohortRetentionFraction",
"type": "TYPE_FLOAT"
}
],
"rows": [
{
"dimensionValues": [{ "value": "cohort_0" },{ "value": "0000" }],
"metricValues": [{ "value": "1" }]
},
{
"dimensionValues": [{ "value": "cohort_1" },{ "value": "0000" }],
"metricValues": [{ "value": "1" }]
},
{
"dimensionValues": [{ "value": "cohort_2" },{ "value": "0000" }],
"metricValues": [{ "value": "1" }]
},
{
"dimensionValues": [{ "value": "cohort_2" },{ "value": "0001" }],
"metricValues": [{ "value": "0.308" }]
},
{
"dimensionValues": [{ "value": "cohort_1" },{ "value": "0001" }],
"metricValues": [{ "value": "0.272" }]
},
{
"dimensionValues": [{ "value": "cohort_2" },{ "value": "0002" }],
"metricValues": [{ "value": "0.257" }]
},
{
"dimensionValues": [{ "value": "cohort_0" },{ "value": "0001" }],
"metricValues": [{ "value": "0.248" }]
},
{
"dimensionValues": [{ "value": "cohort_2" },{ "value": "0003" }],
"metricValues": [{ "value": "0.235" }]
},
{
"dimensionValues": [{ "value": "cohort_2" },{ "value": "0004" }],
"metricValues": [{ "value": "0.211" }]
},
{
"dimensionValues": [{ "value": "cohort_1" },{ "value": "0002" }],
"metricValues": [{ "value": "0.198" }]
},
{
"dimensionValues": [{ "value": "cohort_0" },{ "value": "0002" }],
"metricValues": [{ "value": "0.172" }]
},
{
"dimensionValues": [{ "value": "cohort_1" },{ "value": "0003" }],
"metricValues": [{ "value": "0.167" }]
},
{
"dimensionValues": [{ "value": "cohort_1" },{ "value": "0004" }],
"metricValues": [{ "value": "0.155" }]
},
{
"dimensionValues": [{ "value": "cohort_0" },{ "value": "0003" }],
"metricValues": [{ "value": "0.141" }]
},
{
"dimensionValues": [{ "value": "cohort_0" },{ "value": "0004" }],
"metricValues": [{ "value": "0.118" }]
}
],
"metadata": {},
"rowCount": 15
}
Después de esta respuesta, se muestra un gráfico de este informe de cohorte. Una conclusión de este informe es que la retención de usuarios de 4 días aumentó un 10% en el transcurso de dos semanas. La cohorte más reciente con firstSessionDate
de 2020-11-16
supera la retención de la cohorte anterior con firstSessionDate
de 2020-11-02
.
Cohortes semanales y uso de cohortes con otras funciones de la API
Para quitar la variación diaria en el comportamiento de los usuarios, usa cohortes semanales. En los informes de cohortes semanales, todos los usuarios con firstSessionDate
en la misma semana forman la cohorte. Las semanas comienzan el domingo y terminan el sábado. También en este informe, dividimos la cohorte para comparar a los usuarios con actividad en Rusia con los usuarios con actividad en México. Este corte usa la dimensión country
y un dimensionFilter
para considerar solo los dos países.
La solicitud de informe para estas cohortes es la siguiente:
POST https://analyticsdata.googleapis.com/v1beta/properties/GA_PROPERTY_ID:runReport
{
"dimensions": [
{ "name": "cohort" },
{ "name": "cohortNthWeek" },
{ "name": "country" }
],
"metrics": [{ "name": "cohortActiveUsers" }],
"dimensionFilter": {
"filter": {
"fieldName": "country",
"inListFilter": {
"values": [ "Russia", "Mexico" ]
}
}
},
"cohortSpec": {
"cohorts": [
{
"dimension": "firstSessionDate",
"dateRange": {
"startDate": "2020-10-04",
"endDate": "2020-10-10"
}
}
],
"cohortsRange": {
"endOffset": 5,
"granularity": "WEEKLY"
}
},
}
Para esta solicitud, una respuesta de informe de ejemplo es la siguiente:
{
"dimensionHeaders": [
{ "name": "cohort" },
{ "name": "cohortNthWeek" },
{ "name": "country" }
],
"metricHeaders": [
{ "name": "cohortActiveUsers", "type": "TYPE_INTEGER" }
],
"rows": [
{
"dimensionValues": [
{ "value": "cohort_0" },{ "value": "0000" },{ "value": "Russia" }
],
"metricValues": [{ "value": "105" }]
},
{
"dimensionValues": [
{ "value": "cohort_0" },{ "value": "0000" },{ "value": "Mexico" }
],
"metricValues": [{ "value": "98" }]
},
{
"dimensionValues": [
{ "value": "cohort_0" },{ "value": "0001" },{ "value": "Mexico" }
],
"metricValues": [{ "value": "35" }]
},
{
"dimensionValues": [
{ "value": "cohort_0" },{ "value": "0002" },{ "value": "Mexico" }
],
"metricValues": [{ "value": "24" }]
},
{
"dimensionValues": [
{ "value": "cohort_0" },{ "value": "0001" },{ "value": "Russia" }
],
"metricValues": [{ "value": "23" }]
},
{
"dimensionValues": [
{ "value": "cohort_0" },{ "value": "0004" },{ "value": "Mexico" }
],
"metricValues": [{ "value": "17" }]
},
{
"dimensionValues": [
{ "value": "cohort_0" },{ "value": "0003" },{ "value": "Mexico" }
],
"metricValues": [{ "value": "15" }]
},
{
"dimensionValues": [
{ "value": "cohort_0" },{ "value": "0005" },{ "value": "Mexico" }
],
"metricValues": [{ "value": "15" }]
},
{
"dimensionValues": [
{ "value": "cohort_0" },{ "value": "0002" },{ "value": "Russia" }
],
"metricValues": [{ "value": "3" }]
},
{
"dimensionValues": [
{ "value": "cohort_0" },{ "value": "0003" },{ "value": "Russia" }
],
"metricValues": [{ "value": "1" }]
},
{
"dimensionValues": [
{ "value": "cohort_0" },{ "value": "0004" },{ "value": "Russia" }
],
"metricValues": [{ "value": "1" }]
}
],
"metadata": {},
"rowCount": 11
}
Después de esta respuesta, se muestra un gráfico de este informe de cohorte. Según este informe, esta propiedad tiene un mejor rendimiento en la retención de usuarios con actividad en México que en Rusia.
Comparaciones
Las comparaciones le permiten evaluar subconjuntos de sus datos en paralelo. Para definir las comparaciones, especifica el campo comparisons
en una definición de informe. La función Comparaciones de la API de datos es similar a las comparaciones en el frontend de Google Analytics.
Para obtener documentación detallada de cada campo de la API, consulta la referencia de REST para la comparación.
Crea una comparación
Puedes crear una comparación independiente para cada conjunto de datos que desees comparar. Por ejemplo, si quieres comparar los datos web y de aplicaciones, puedes crear dos comparaciones: una para los datos web y otra para los datos de iOS y Android.
Este es un informe de muestra que define dos comparaciones y muestra los usuarios activos desglosados por país.
La primera comparación, denominada "Tráfico de aplicaciones", usa inListFilter
para hacer coincidir la dimensión platform
con los valores "iOS" y "Android". La segunda comparación, llamada "Tráfico web", usa stringFilter
para hacer coincidir la dimensión platform
con "web".
POST https://analyticsdata.googleapis.com/v1beta/properties/GA_PROPERTY_ID:runReport
{
"comparisons": [
{
"name": "App traffic",
"dimensionFilter": {
"filter": {
"fieldName": "platform",
"inListFilter": {
"values": [
"iOS",
"Android"
]
}
}
}
},
{
"name": "Web traffic",
"dimensionFilter": {
"filter": {
"fieldName": "platform",
"stringFilter": {
"matchType": "EXACT",
"value": "web"
}
}
}
}
],
"dateRanges": [
{
"startDate": "2024-05-01",
"endDate": "2024-05-15"
}
],
"dimensions": [
{
"name": "country"
}
],
"metrics": [
{
"name": "activeUsers"
}
]
}
Para todas las solicitudes que usan la función de comparaciones, el campo comparison
se agrega automáticamente al informe generado. Este campo contiene el nombre de la comparación proporcionada en la solicitud.
Este es un fragmento de ejemplo de una respuesta que contiene comparaciones:
{
"dimensionHeaders": [
{
"name": "comparison"
},
{
"name": "country"
}
],
"metricHeaders": [
{
"name": "activeUsers",
"type": "TYPE_INTEGER"
}
],
"rows": [
{
"dimensionValues": [
{
"value": "Web traffic"
},
{
"value": "United States"
}
],
"metricValues": [
{
"value": "638572"
}
]
},
{
"dimensionValues": [
{
"value": "Web traffic"
},
{
"value": "Japan"
}
],
"metricValues": [
{
"value": "376578"
}
]
},
{
"dimensionValues": [
{
"value": "App traffic"
},
{
"value": "United States"
}
],
"metricValues": [
{
"value": "79527"
}
]
},
...
],
...
}