खास जानकारी

Google Analytics Data API v1 की मदद से पिवट टेबल बनाई जा सकती हैं. पिवट टेबल, डेटा की खास जानकारी देने वाला ऐसा टूल है जो आपके डेटा को एक या उससे ज़्यादा डाइमेंशन पर पिवट (घुमाकर) करके टेबल में जानकारी को फिर से व्यवस्थित करके डेटा को विज़ुअलाइज़ करता है.

उदाहरण के लिए, नीचे दी गई रॉ डेटा टेबल देखें:

रॉ डेटा टेबल

इस डेटा का इस्तेमाल करके एक पिवट टेबल बनाई जा सकती है, जिसमें अलग से पिवट के रूप में देश और भाषा के डाइमेंशन चुनकर, ब्राउज़र के आधार पर सेशन के डेटा को बांटा जा सकता है.

पिवट की गई डेटा टेबल

मुख्य रिपोर्ट के साथ शेयर की गई सुविधाएं

पिवट रिपोर्टिंग अनुरोधों का सिमैंटिक एक ही होता है, जबकि कई सुविधाओं के लिए मुख्य रिपोर्ट अनुरोधों का मतलब एक जैसा होता है. उदाहरण के लिए, पेजिनेशन, डाइमेंशन फ़िल्टर, और उपयोगकर्ता प्रॉपर्टी, पिवट रिपोर्ट में कोर रिपोर्ट की तरह ही काम करती हैं. यह गाइड, पिवट रिपोर्टिंग सुविधाओं पर फ़ोकस करती है. Data API v1 की मुख्य रिपोर्टिंग की सुविधा के बारे में जानने के लिए, रिपोर्टिंग की बुनियादी जानकारी वाली गाइड और इस्तेमाल के बेहतर उदाहरणों से जुड़ी गाइड पढ़ें.

पिवट रिपोर्टिंग के तरीके

Data API v1, रिपोर्टिंग के इन तरीकों में पिवट फ़ंक्शन के साथ काम करता है:

  • runPivotReport यह तरीका आपके Google Analytics इवेंट डेटा की कस्टमाइज़ की गई पिवट रिपोर्ट दिखाता है. हर पिवट, रिपोर्ट रिस्पॉन्स में दिखने वाले डाइमेंशन कॉलम और पंक्तियों की जानकारी देता है.

  • batchRunPivotReports runPivotReport तरीके का यह बैच वर्शन है. इसकी मदद से, एक एपीआई कॉल का इस्तेमाल करके कई रिपोर्ट जनरेट की जा सकती हैं.

रिपोर्टिंग इकाई चुनना

Data API v1 के सभी तरीकों के लिए, यूआरएल अनुरोध पाथ में Google Analytics 4 प्रॉपर्टी आइडेंटिफ़ायर की जानकारी, properties/GA4_PROPERTY_ID के तौर पर देनी होगी. जैसे:

  POST  https://analyticsdata.googleapis.com/v1beta/properties/GA4_PROPERTY_ID:runPivotReport

जनरेट की गई रिपोर्ट, आपकी तय की गई Google Analytics 4 प्रॉपर्टी में इकट्ठा किए गए Google Analytics के इवेंट डेटा के आधार पर जनरेट होगी.

अगर Data API क्लाइंट लाइब्रेरी का इस्तेमाल किया जा रहा है, तो अनुरोध के यूआरएल पाथ में मैन्युअल तरीके से बदलाव करने की ज़रूरत नहीं है. ज़्यादातर एपीआई क्लाइंट ऐसा property पैरामीटर देते हैं जो properties/GA4_PROPERTY_ID के तौर पर स्ट्रिंग होना चाहिए. क्लाइंट लाइब्रेरी को इस्तेमाल करने के उदाहरणों के लिए, आसानी से सिखाने वाली गाइड देखें.

पिवट रिपोर्ट का अनुरोध

पिवट टेबल की मदद से कोई अनुरोध बनाने के लिए, runPivotReport या batchRunPivotReports तरीके का इस्तेमाल करें.

पिवट किए गए डेटा का अनुरोध करने के लिए, RunPivotReportRequest ऑब्जेक्ट बनाया जा सकता है. हम इन अनुरोध पैरामीटर से शुरू करने का सुझाव देते हैं:

  • dateRanges फ़ील्ड में मान्य एंट्री.
  • डाइमेंशन फ़ील्ड में कम से कम एक मान्य एंट्री हो.
  • metrics फ़ील्ड में कम से कम एक मान्य एंट्री हो.
  • पिवट फ़ील्ड में कम से कम दो मान्य पिवट एंट्री.

यहां सुझाए गए फ़ील्ड के साथ अनुरोध का एक नमूना दिया गया है:

HTTP

POST https://analyticsdata.googleapis.com/v1beta/properties/GA4_PROPERTY_ID:runPivotReport
  {
    "dateRanges": [{ "startDate": "2020-09-01", "endDate": "2020-09-15" }],
    "dimensions": [
        { "name": "browser" },
        { "name": "country" },
        { "name": "language" }
      ],
    "metrics": [{ "name": "sessions" }],
    "pivots": [
      {
        "fieldNames": [
          "browser"
        ],
        "limit": 5
      },
      {
        "fieldNames": [
          "country"
        ],
        "limit": 250
      },
      {
        "fieldNames": [
          "language"
        ],
        "limit": 15
      }
    ]
  }

पिवट

रिपोर्ट पिवट तय करने के लिए, अनुरोध के मुख्य हिस्से के pivot फ़ील्ड में पिवट ऑब्जेक्ट का इस्तेमाल करें. हर Pivot, रिपोर्ट रिस्पॉन्स में दिखने वाले डाइमेंशन कॉलम और पंक्तियों की जानकारी देता है.

Data API v1 में कई पिवट इस्तेमाल किए जा सकते हैं. हालांकि, इसके लिए ज़रूरी है कि हर पिवट के लिए limit पैरामीटर का प्रॉडक्ट 1,00,000 से ज़्यादा न हो.

नीचे एक स्निपेट दिया गया है, जो देश के हिसाब से सेशन की संख्या की रिपोर्ट बनाने के लिए, pivots के इस्तेमाल को दिखाता है. इस रिपोर्ट को browser डाइमेंशन के हिसाब से पिवट किया जाता है. ध्यान दें कि क्वेरी, क्रम से लगाने के लिए orderBys फ़ील्ड का इस्तेमाल कैसे करती है. साथ ही, पेज पर नंबर डालना लागू करने के लिए, limit और offset फ़ील्ड का इस्तेमाल करती है.

    "pivots": [
      {
        "fieldNames": [
          "country"
        ],
        "limit": 250,
        "orderBys": [
          {
            "dimension": {
              "dimensionName": "country"
            }
          }
        ]
      },
      {
        "fieldNames": [
          "browser"
        ],
        "offset": 3,
        "limit": 3,
        "orderBys": [
          {
            "metric": {
              "metricName": "sessions"
            },
            "desc": true
          }
        ]
      }
    ],
    ...

डाइमेंशन

डाइमेंशन आपकी वेबसाइट या ऐप्लिकेशन के लिए, इवेंट डेटा की जानकारी देते हैं और उनका ग्रुप बनाते हैं. उदाहरण के लिए, city डाइमेंशन से उस शहर ("पेरिस" या "न्यूयॉर्क") की जानकारी मिलती है जहां से हर इवेंट शुरू हुआ था. रिपोर्ट अनुरोध में, शून्य या ज़्यादा डाइमेंशन दिए जा सकते हैं.

डाइमेंशन को, अनुरोध के मुख्य हिस्से के डाइमेंशन फ़ील्ड में तय किया जाना चाहिए. किसी रिपोर्ट में दिखने के लिए, वे डाइमेंशन, Pivot ऑब्जेक्ट के fieldNames फ़ील्ड में भी शामिल होने चाहिए. अगर किसी पिवट क्वेरी के किसी भी पिवट में डाइमेंशन का इस्तेमाल नहीं किया जाता है, तो वह रिपोर्ट में नहीं दिखेगा. पिवट के fieldNames में हर डाइमेंशन मौजूद नहीं होना चाहिए. डाइमेंशन का इस्तेमाल खास तौर पर फ़िल्टर में किया जा सकता है, किसी पिवट के fieldNames में नहीं.

नीचे एक स्निपेट दिया गया है, जो browser, country, और language पिवट वाली टेबल के लिए, dimension और fieldNames फ़ील्ड के इस्तेमाल को दिखाता है:

    "pivots": [
      {
        "fieldNames": [
          "browser"
        ],
        "limit": 5,
        "orderBys": [
          {
            "metric": {
              "metricName": "sessions"
            },
            "desc": true
          }
        ]
      },
      {
        "fieldNames": [
          "country"
        ],
        "limit": 250,
        "orderBys": [
          {
            "dimension": {
              "dimensionName": "country"
            }
          }
        ]
      },
      {
        "fieldNames": [
          "language"
        ],
        "limit": 10
      }
    ],

मेट्रिक

मेट्रिक, आपकी वेबसाइट या ऐप्लिकेशन के इवेंट डेटा की संख्यात्मक माप होती हैं. रिपोर्ट के अनुरोध में, एक या उससे ज़्यादा मेट्रिक के बारे में बताया जा सकता है. अनुरोधों में शामिल किए जाने वाले एपीआई मेट्रिक के नामों की पूरी सूची देखने के लिए, एपीआई मेट्रिक देखें.

पिवट रिपोर्ट के अनुरोधों में, मेट्रिक को अनुरोध के मुख्य हिस्से के metrics फ़ील्ड का इस्तेमाल करके तय किया जाता है. यह रिपोर्टिंग के मुख्य तरीकों की तरह ही होता है.

नीचे दिए गए उदाहरण में, किसी रिपोर्ट में मेट्रिक की वैल्यू के तौर पर इस्तेमाल की जाने वाली सेशन की संख्या की जानकारी दी गई है:

    "metrics": [
      {
        "name": "sessions"
      }
    ],

मेट्रिक एग्रीगेशन

हर पिवट के लिए एग्रीगेट की गई मेट्रिक वैल्यू की गिनती करने के लिए, पिवट ऑब्जेक्ट के metricAggregations फ़ील्ड का इस्तेमाल करें.

एग्रीगेशन का हिसाब सिर्फ़ तब लगाया जाएगा, जब किसी अनुरोध में metricAggregations फ़ील्ड के बारे में बताया गया हो.

नीचे एक क्वेरी का स्निपेट दिया गया है, जिसमें browser पिवट डाइमेंशन के लिए कुल वैल्यू का अनुरोध किया गया है:

"pivots": [
  {
    "fieldNames": [
      "browser"
    ],
    "limit": 10,
    "metricAggregations": [
      "TOTAL",
    ]
  },
  ...

कैलकुलेट की गई मेट्रिक, RunPivotReportResponse ऑब्जेक्ट के एग्रीगेट फ़ील्ड में दिखाई जाती हैं. एग्रीगेट की गई मेट्रिक लाइनों के लिए, dimensionValues फ़ील्ड में RESERVED_TOTAL, RESERVED_MAX या RESERVED_MIN जैसी खास वैल्यू होती है.

  "aggregates": [
    {
      "dimensionValues": [
        {
          "value": "Chrome"
        },
        {
          "value": "RESERVED_TOTAL"
        },
        {
          "value": "RESERVED_TOTAL"
        }
      ],
      "metricValues": [
        {
          "value": "4"
        }
      ]
    },
    {
      "dimensionValues": [
        {
          "value": "Firefox"
        },
        {
          "value": "RESERVED_TOTAL"
        },
        {
          "value": "RESERVED_TOTAL"
        }
      ],
      "metricValues": [
        {
          "value": "6"
        }
      ]
    },
  ....

  }

खोज नतीजों को पेजों में बांटना

मूल रिपोर्टिंग के तरीकों की तरह ही, पिवट अनुरोधों की मदद से पेज पर नंबर डालने के लिए, पिवट ऑब्जेक्ट में सीमा और ऑफ़सेट फ़ील्ड तय किए जा सकते हैं. पेज पर नंबर डालने की सेटिंग, हर पिवट पर अलग-अलग लागू की जाती हैं. हर Pivot ऑब्जेक्ट के लिए limit फ़ील्ड ज़रूरी है, ताकि रिपोर्ट के एलिमेंट की संख्या सीमित की जा सके.

जब तक हर पिवट के लिए limit पैरामीटर का प्रॉडक्ट 1,00,000 से ज़्यादा नहीं होता, तब तक Data API v1 कई पिवट के साथ काम करता है.

नीचे 10 के ऑफ़सेट के साथ अगले पांच language डाइमेंशन पाने के लिए offset और limit फ़ील्ड के इस्तेमाल को दिखाने वाला स्निपेट दिया गया है:

      {
        "fieldNames": [
          "language"
        ],
        "offset": 10,
        "limit": 5
      }

फ़िल्टर करना

अगर पिवट रिपोर्टिंग के अनुरोध में डाइमेंशन फ़िल्टर करना ज़रूरी है, तो मुख्य रिपोर्टिंग फ़ंक्शन की तरह ही, अनुरोध के दायरे वाले डाइमेंशन फ़िल्टर का इस्तेमाल करना चाहिए.

क्रम से लगाना

पिवट रिपोर्ट क्वेरी के ऑर्डर के व्यवहार को पिवट ऑब्जेक्ट के orderBys फ़ील्ड का इस्तेमाल करके, अलग-अलग कंट्रोल किया जा सकता है. इस ऑब्जेक्ट में OrderBy ऑब्जेक्ट की सूची होती है.

हर OrderBy में, इनमें से कोई एक चीज़ हो सकती है:

  • DimensionOrderBy, नतीजों को डाइमेंशन की वैल्यू के हिसाब से क्रम में लगाता है.
  • MetricOrderBy, नतीजों को मेट्रिक की वैल्यू के मुताबिक क्रम से लगाता है.
  • PivotOrderBy, पिवट क्वेरी में इस्तेमाल किया जाता है. साथ ही, इसमें पिवट कॉलम ग्रुप में मौजूद मेट्रिक की वैल्यू के हिसाब से नतीजों को क्रम से लगाया जाता है.

इस उदाहरण में पिवट डेफ़िनिशन के लिए एक स्निपेट दिखाया गया है, जो रिपोर्ट को browser डाइमेंशन पर पिवट करता है. साथ ही, नतीजों को sessions मेट्रिक के हिसाब से घटते क्रम में दिखाता है.

      {
        "fieldNames": [
          "browser"
        ],
        "limit": 5,
        "orderBys": [
          {
            "metric": {
              "metricName": "sessions"
            },
            "desc": true
          }
        ]
      }

जवाब की शिकायत करें

पिवट रिपोर्ट एपीआई अनुरोध का पिवट रिपोर्ट रिस्पॉन्स, मुख्य रूप से एक हेडर और पंक्तियां होती है.

रिस्पॉन्स हेडर

पिवट रिपोर्ट के हेडर में PivotHeaders, DimensionHeaders और MetricHeaders को शामिल होने का विकल्प होता है, जो पिवट रिपोर्ट के कॉलम की सूची बनाते हैं.

उदाहरण के लिए, browser, country, और language पिवट डाइमेंशन वाली रिपोर्ट और sessions मेट्रिक के हेडर इस तरह दिखेंगे:

{
  "pivotHeaders": [
    {
      "pivotDimensionHeaders": [
        {
          "dimensionValues": [
            {
              "value": "Chrome"
            }
          ]
        },
        {
          "dimensionValues": [
            {
              "value": "Firefox"
            }
          ]
        },
        ...

      ],
      ...
    },
    {
      "pivotDimensionHeaders": [
        {
          "dimensionValues": [
            {
              "value": "United States"
            }
          ]
        },
        {
          "dimensionValues": [
            {
              "value": "Canada"
            }
          ]
        },
        ...

      ],
      ...
    },
    {
      "pivotDimensionHeaders": [
        {
          "dimensionValues": [
            {
              "value": "English"
            }
          ]
        },
        {
          "dimensionValues": [
            {
              "value": "French"
            }
          ]
        },
        ...

      ],
      ...
    }
  ],
  "dimensionHeaders": [
    {
      "name": "browser"
    },
    {
      "name": "country"
    },
    {
      "name": "language"
    }
  ],
  "metricHeaders": [
    {
      "name": "sessions",
      "type": "TYPE_INTEGER"
    }
  ],
  ...

}

नीचे दिया गया चार्ट पिवट रिपोर्ट के हर एक कॉम्पोनेंट की भूमिका को दिखाता है, जो पिवट रिपोर्ट को रेंडर करने में मददगार है:

रॉ डेटा टेबल

जवाब वाली पंक्तियां

runPivotReport और batchRunPivotReports चैनल के पिवट रिपोर्ट रिस्पॉन्स, रिपोर्टिंग के मुख्य तरीकों, जैसे कि runReport और batchRunReports के रिस्पॉन्स से अलग होता है. इसमें हर पिवट रिपोर्ट रिस्पॉन्स लाइन, टेबल की एक सेल को दिखाती है, जबकि सामान्य रिपोर्ट में एक रिस्पॉन्स वाली लाइन, पूरी टेबल लाइन को दिखाती है.

यहां browser, country, और language पिवट डाइमेंशन के साथ-साथ sessions मेट्रिक वाली क्वेरी के लिए, पिवट रिपोर्ट में मिले रिस्पॉन्स का एक हिस्सा दिया गया है. पिवट रिपोर्ट का हर सेल अलग-अलग दिखाया जाता है:

  "rows": [
    {
      "dimensionValues": [
        {
          "value": "Chrome"
        },
        {
          "value": "United States"
        },
        {
          "value": "English"
        }
      ],
      "metricValues": [
        {
          "value": "1"
        }
      ]
    },
    {
      "dimensionValues": [
        {
          "value": "Firefox"
        },
        {
          "value": "Canada"
        },
        {
          "value": "French"
        }
      ],
      "metricValues": [
        {
          "value": "3"
        }
      ]
    },
    ...

  ]

यह डेटा, नीचे दी गई टेबल में हाइलाइट की गई दो सेल से जुड़ा होता है:

रॉ डेटा टेबल

क्लाइंट लाइब्रेरी

क्लाइंट लाइब्रेरी को इंस्टॉल और कॉन्फ़िगर करने के तरीके के बारे में जानने के लिए, क्विक स्टार्ट गाइड देखें.

नीचे Python क्लाइंट लाइब्रेरी का इस्तेमाल करने का एक उदाहरण दिया गया है. यह देश के हिसाब से सेशन की गिनती की रिपोर्ट बनाने के लिए, ब्राउज़र डाइमेंशन के हिसाब से पिवट क्वेरी चलाता है.

from google.analytics.data_v1beta import BetaAnalyticsDataClient
from google.analytics.data_v1beta.types import (
    DateRange,
    Dimension,
    Metric,
    OrderBy,
    Pivot,
    RunPivotReportRequest,
)


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


def run_pivot_report(property_id="YOUR-GA4-PROPERTY-ID"):
    """Runs a pivot query to build a report of session counts by country,
    pivoted by the browser dimension."""
    client = BetaAnalyticsDataClient()

    request = RunPivotReportRequest(
        property=f"properties/{property_id}",
        date_ranges=[DateRange(start_date="2021-01-01", end_date="2021-01-30")],
        pivots=[
            Pivot(
                field_names=["country"],
                limit=250,
                order_bys=[
                    OrderBy(
                        dimension=OrderBy.DimensionOrderBy(dimension_name="country")
                    )
                ],
            ),
            Pivot(
                field_names=["browser"],
                offset=3,
                limit=3,
                order_bys=[
                    OrderBy(
                        metric=OrderBy.MetricOrderBy(metric_name="sessions"), desc=True
                    )
                ],
            ),
        ],
        metrics=[Metric(name="sessions")],
        dimensions=[Dimension(name="country"), Dimension(name="browser")],
    )
    response = client.run_pivot_report(request)
    print_run_pivot_report_response(response)


def print_run_pivot_report_response(response):
    """Prints results of a runPivotReport call."""
    print("Report result:")
    for row in response.rows:
        for dimension_value in row.dimension_values:
            print(dimension_value.value)

        for metric_value in row.metric_values:
            print(metric_value.value)


डेमो ऐप्लिकेशन

JavaScript का इस्तेमाल करके पिवट रिपोर्ट बनाने और दिखाने के उदाहरण के लिए Google Analytics एपीआई v1 पिवट रिपोर्ट डेमो ऐप्लिकेशन देखें.