शुरू करना

कन्वर्ज़न रिकॉर्ड करने के लिए, आपको अपने Google Ads कन्वर्ज़न खाते में कन्वर्ज़न ट्रैकिंग की सुविधा चालू करनी होगी. इस गाइड में, कन्वर्ज़न ट्रैकिंग की सुविधा चालू है या नहीं, इसकी पुष्टि करने का तरीका बताया गया है. साथ ही, अगर यह सुविधा पहले से चालू नहीं है, तो इसे चालू करने का तरीका भी बताया गया है. इसके अलावा, इसमें मौजूदा कन्वर्ज़न ऐक्शन के बारे में जानकारी पाने का तरीका भी बताया गया है.

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

कन्वर्ज़न ट्रैक करने के लिए अपनी वेबसाइट सेट अप करना

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

अपने Google Ads कन्वर्ज़न खाते में कन्वर्ज़न ट्रैकिंग की सुविधा चालू करना

अपने कन्वर्ज़न ट्रैकिंग सेटअप के बारे में जानकारी पाना

अपने खाते के कन्वर्ज़न ट्रैकिंग सेटअप की जांच की जा सकती है. साथ ही, ConversionTrackingSetting के लिए Customer संसाधन से क्वेरी करके, यह पुष्टि की जा सकती है कि कन्वर्ज़न ट्रैकिंग चालू है या नहीं. GoogleAdsService.SearchStream के साथ यह क्वेरी दें:

SELECT
  customer.conversion_tracking_setting.google_ads_conversion_customer,
  customer.conversion_tracking_setting.conversion_tracking_status,
  customer.conversion_tracking_setting.conversion_tracking_id,
  customer.conversion_tracking_setting.cross_account_conversion_tracking_id
FROM customer

google_ads_conversion_customer फ़ील्ड से उस Google Ads खाते का पता चलता है जो इस ग्राहक के लिए कन्वर्ज़न बनाता और मैनेज करता है. कई खातों में होने वाले कन्वर्ज़न को ट्रैक करने की सुविधा का इस्तेमाल करने वाले ग्राहकों के लिए, यह मैनेजर खाते का आईडी होता है. कन्वर्ज़न बनाने और मैनेज करने के लिए, Google Ads कन्वर्ज़न ग्राहक आईडी को Google Ads API अनुरोधों में customer_id के तौर पर दिया जाना चाहिए. ध्यान दें कि कन्वर्ज़न ट्रैकिंग चालू न होने पर भी, इस फ़ील्ड में जानकारी अपने-आप भर जाती है.

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

Google Ads कन्वर्ज़न ग्राहक के तहत कन्वर्ज़न ऐक्शन बनाना

अगर conversion_tracking_status की वैल्यू NOT_CONVERSION_TRACKED है, तो इसका मतलब है कि खाते के लिए कन्वर्ज़न ट्रैकिंग की सुविधा चालू नहीं है. Google Ads कन्वर्ज़न खाते में कम से कम एक ConversionAction बनाकर, कन्वर्ज़न ट्रैकिंग की सुविधा चालू करें. उदाहरण के लिए, नीचे दिया गया तरीका अपनाएं. इसके अलावा, आपको जिस कन्वर्ज़न टाइप को चालू करना है उसके लिए, सहायता केंद्र में दिए गए निर्देशों का पालन करके, यूज़र इंटरफ़ेस (यूआई) में कन्वर्ज़न ऐक्शन बनाया जा सकता है.

ध्यान दें कि Google Ads API से भेजे जाने पर, बेहतर कन्वर्ज़न ट्रैकिंग की सुविधा अपने-आप चालू हो जाती है. हालांकि, Google Ads के यूज़र इंटरफ़ेस (यूआई) से इसे बंद किया जा सकता है.

कोड का उदाहरण

Java

private void runExample(GoogleAdsClient googleAdsClient, long customerId) {

  // Creates a ConversionAction.
  ConversionAction conversionAction =
      ConversionAction.newBuilder()
          // Note that conversion action names must be unique. If a conversion action already
          // exists with the specified conversion_action_name the create operation will fail with
          // a ConversionActionError.DUPLICATE_NAME error.
          .setName("Earth to Mars Cruises Conversion #" + getPrintableDateTime())
          .setCategory(ConversionActionCategory.DEFAULT)
          .setType(ConversionActionType.WEBPAGE)
          .setStatus(ConversionActionStatus.ENABLED)
          .setViewThroughLookbackWindowDays(15L)
          .setValueSettings(
              ValueSettings.newBuilder()
                  .setDefaultValue(23.41)
                  .setAlwaysUseDefaultValue(true)
                  .build())
          .build();

  // Creates the operation.
  ConversionActionOperation operation =
      ConversionActionOperation.newBuilder().setCreate(conversionAction).build();

  try (ConversionActionServiceClient conversionActionServiceClient =
      googleAdsClient.getLatestVersion().createConversionActionServiceClient()) {
    MutateConversionActionsResponse response =
        conversionActionServiceClient.mutateConversionActions(
            Long.toString(customerId), Collections.singletonList(operation));
    System.out.printf("Added %d conversion actions:%n", response.getResultsCount());
    for (MutateConversionActionResult result : response.getResultsList()) {
      System.out.printf(
          "New conversion action added with resource name: '%s'%n", result.getResourceName());
    }
  }
}
      

C#

public void Run(GoogleAdsClient client, long customerId)
{
    // Get the ConversionActionService.
    ConversionActionServiceClient conversionActionService =
        client.GetService(Services.V20.ConversionActionService);

    // Note that conversion action names must be unique.
    // If a conversion action already exists with the specified name the create operation
    // will fail with a ConversionAction.DUPLICATE_NAME error.
    string ConversionActionName = "Earth to Mars Cruises Conversion #"
        + ExampleUtilities.GetRandomString();

    // Add a conversion action.
    ConversionAction conversionAction = new ConversionAction()
    {
        Name = ConversionActionName,
        Category = ConversionActionCategory.Default,
        Type = ConversionActionType.Webpage,
        Status = ConversionActionStatus.Enabled,
        ViewThroughLookbackWindowDays = 15,
        ValueSettings = new ConversionAction.Types.ValueSettings()
        {
            DefaultValue = 23.41,
            AlwaysUseDefaultValue = true
        }
    };

    // Create the operation.
    ConversionActionOperation operation = new ConversionActionOperation()
    {
        Create = conversionAction
    };

    try
    {
        // Create the conversion action.
        MutateConversionActionsResponse response =
            conversionActionService.MutateConversionActions(customerId.ToString(),
                    new ConversionActionOperation[] { operation });

        // Display the results.
        foreach (MutateConversionActionResult newConversionAction in response.Results)
        {
            Console.WriteLine($"New conversion action with resource name = " +
                $"'{newConversionAction.ResourceName}' was added.");
        }
    }
    catch (GoogleAdsException e)
    {
        Console.WriteLine("Failure:");
        Console.WriteLine($"Message: {e.Message}");
        Console.WriteLine($"Failure: {e.Failure}");
        Console.WriteLine($"Request ID: {e.RequestId}");
        throw;
    }
}
      

PHP

public static function runExample(GoogleAdsClient $googleAdsClient, int $customerId)
{
    // Creates a conversion action.
    $conversionAction = new ConversionAction([
        // Note that conversion action names must be unique.
        // If a conversion action already exists with the specified conversion_action_name
        // the create operation will fail with a ConversionActionError.DUPLICATE_NAME error.
        'name' => 'Earth to Mars Cruises Conversion #' . Helper::getPrintableDatetime(),
        'category' => ConversionActionCategory::PBDEFAULT,
        'type' => ConversionActionType::WEBPAGE,
        'status' => ConversionActionStatus::ENABLED,
        'view_through_lookback_window_days' => 15,
        'value_settings' => new ValueSettings([
            'default_value' => 23.41,
            'always_use_default_value' => true
        ])
    ]);

    // Creates a conversion action operation.
    $conversionActionOperation = new ConversionActionOperation();
    $conversionActionOperation->setCreate($conversionAction);

    // Issues a mutate request to add the conversion action.
    $conversionActionServiceClient = $googleAdsClient->getConversionActionServiceClient();
    $response = $conversionActionServiceClient->mutateConversionActions(
        MutateConversionActionsRequest::build($customerId, [$conversionActionOperation])
    );

    printf("Added %d conversion actions:%s", $response->getResults()->count(), PHP_EOL);

    foreach ($response->getResults() as $addedConversionAction) {
        /** @var ConversionAction $addedConversionAction */
        printf(
            "New conversion action added with resource name: '%s'%s",
            $addedConversionAction->getResourceName(),
            PHP_EOL
        );
    }
}
      

Python

def main(client, customer_id):
    conversion_action_service = client.get_service("ConversionActionService")

    # Create the operation.
    conversion_action_operation = client.get_type("ConversionActionOperation")

    # Create conversion action.
    conversion_action = conversion_action_operation.create

    # Note that conversion action names must be unique. If a conversion action
    # already exists with the specified conversion_action_name, the create
    # operation will fail with a ConversionActionError.DUPLICATE_NAME error.
    conversion_action.name = f"Earth to Mars Cruises Conversion {uuid.uuid4()}"
    conversion_action.type_ = (
        client.enums.ConversionActionTypeEnum.UPLOAD_CLICKS
    )
    conversion_action.category = (
        client.enums.ConversionActionCategoryEnum.DEFAULT
    )
    conversion_action.status = client.enums.ConversionActionStatusEnum.ENABLED
    conversion_action.view_through_lookback_window_days = 15

    # Create a value settings object.
    value_settings = conversion_action.value_settings
    value_settings.default_value = 15.0
    value_settings.always_use_default_value = True

    # Add the conversion action.
    conversion_action_response = (
        conversion_action_service.mutate_conversion_actions(
            customer_id=customer_id,
            operations=[conversion_action_operation],
        )
    )

    print(
        "Created conversion action "
        f'"{conversion_action_response.results[0].resource_name}".'
    )
      

Ruby

def add_conversion_action(customer_id)
  # GoogleAdsClient will read a config file from
  # ENV['HOME']/google_ads_config.rb when called without parameters
  client = Google::Ads::GoogleAds::GoogleAdsClient.new


  # Add a conversion action.
  conversion_action = client.resource.conversion_action do |ca|
    ca.name = "Earth to Mars Cruises Conversion #{(Time.new.to_f * 100).to_i}"
    ca.type = :UPLOAD_CLICKS
    ca.category = :DEFAULT
    ca.status = :ENABLED
    ca.view_through_lookback_window_days = 15

    # Create a value settings object.
    ca.value_settings = client.resource.value_settings do |vs|
      vs.default_value = 15
      vs.always_use_default_value = true
    end
  end

  # Create the operation.
  conversion_action_operation = client.operation.create_resource.conversion_action(conversion_action)

  # Add the ad group ad.
  response = client.service.conversion_action.mutate_conversion_actions(
    customer_id: customer_id,
    operations: [conversion_action_operation],
  )

  puts "New conversion action with resource name = #{response.results.first.resource_name}."
end
      

Perl

sub add_conversion_action {
  my ($api_client, $customer_id) = @_;

  # Note that conversion action names must be unique.
  # If a conversion action already exists with the specified conversion_action_name,
  # the create operation fails with error ConversionActionError.DUPLICATE_NAME.
  my $conversion_action_name = "Earth to Mars Cruises Conversion #" . uniqid();

  # Create a conversion action.
  my $conversion_action =
    Google::Ads::GoogleAds::V20::Resources::ConversionAction->new({
      name                          => $conversion_action_name,
      category                      => DEFAULT,
      type                          => WEBPAGE,
      status                        => ENABLED,
      viewThroughLookbackWindowDays => 15,
      valueSettings                 =>
        Google::Ads::GoogleAds::V20::Resources::ValueSettings->new({
          defaultValue          => 23.41,
          alwaysUseDefaultValue => "true"
        })});

  # Create a conversion action operation.
  my $conversion_action_operation =
    Google::Ads::GoogleAds::V20::Services::ConversionActionService::ConversionActionOperation
    ->new({create => $conversion_action});

  # Add the conversion action.
  my $conversion_actions_response =
    $api_client->ConversionActionService()->mutate({
      customerId => $customer_id,
      operations => [$conversion_action_operation]});

  printf "New conversion action added with resource name: '%s'.\n",
    $conversion_actions_response->{results}[0]{resourceName};

  return 1;
}
      

पक्का करें कि conversion_action_type, सही ConversionActionType वैल्यू पर सेट हो. Google Ads API में कन्वर्ज़न ऐक्शन बनाने के बारे में ज़्यादा जानकारी के लिए, कन्वर्ज़न ऐक्शन बनाना लेख पढ़ें.

किसी मौजूदा कन्वर्ज़न ऐक्शन को वापस लाना

किसी मौजूदा कन्वर्ज़न ऐक्शन की जानकारी पाने के लिए, यह क्वेरी दें. पक्का करें कि अनुरोध में मौजूद ग्राहक आईडी, उस Google Ads कन्वर्ज़न ग्राहक पर सेट हो जिसकी पहचान आपने ऊपर की है. साथ ही, कन्वर्ज़न ऐक्शन टाइप सही ConversionActionType वैल्यू पर सेट हो.

SELECT
  conversion_action.resource_name,
  conversion_action.name,
  conversion_action.status
FROM conversion_action
WHERE conversion_action.type = 'INSERT_CONVERSION_ACTION_TYPE'

कई खातों में होने वाले कन्वर्ज़न ट्रैक करना

अगर कई खातों में होने वाले कन्वर्ज़न को ट्रैक करने की सुविधा का इस्तेमाल किया जा रहा है, तो ConversionActionService ये कन्वर्ज़न ऐक्शन दिखाता है:

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

v19.1 से, क्लाइंट खाते बनाते समय, कई खातों में होने वाले कन्वर्ज़न की ट्रैकिंग के लिए ऑप्ट-इन करने के लिए, Google Ads API का इस्तेमाल किया जा सकता है.

नया Customer बनाते समय, conversion_tracking_setting.google_ads_conversion_customer को उस मैनेजर खाते के रिसॉर्स के नाम पर सेट करें जिसे क्लाइंट खाते की ओर से कन्वर्ज़न ऐक्शन मैनेज करने चाहिए. यह मैनेजर खाता, वह खाता भी होना चाहिए जिसने नए क्लाइंट खाते के लिए create अनुरोध किया है.

v20 से, क्लाइंट खाते बनाते समय और अपडेट करते समय, क्रॉस-कन्वर्ज़न ट्रैकिंग में ऑप्ट इन करने के लिए, Google Ads API का इस्तेमाल किया जा सकता है.

किसी मौजूदा क्लाइंट खाते को अपडेट करते समय, conversion_tracking_setting.google_ads_conversion_customer फ़ील्ड को सेट करके, कई खातों में होने वाले कन्वर्ज़न को ट्रैक करने की सुविधा के लिए ऑप्ट-इन किया जा सकता है. इस फ़ील्ड को उस मैनेजर खाते के रिसॉर्स के नाम पर सेट किया जाना चाहिए जिसे क्लाइंट खाते की ओर से कन्वर्ज़न ऐक्शन मैनेज करने चाहिए. यह मैनेजर खाता, क्लाइंट खाते के लिए update अनुरोध करने वाला खाता भी होना चाहिए.

कई खातों में होने वाले कन्वर्ज़न को ट्रैक करने की सुविधा के लिए ऑप्ट-इन करने या किसी मौजूदा क्लाइंट खाते के लिए कन्वर्ज़न ट्रैकिंग मैनेजर को स्विच करने पर, वही सावधानियां बरतना ज़रूरी है जो यूज़र इंटरफ़ेस (यूआई) में यह बदलाव करने पर बरती जाती हैं. खास तौर पर:

  • क्लाइंट खाता, कन्वर्ज़न वैल्यू के डिफ़ॉल्ट नियमों और अपने नए कन्वर्ज़न ट्रैकिंग मैनेजर के ग्राहक लाइफ़साइकल के डिफ़ॉल्ट लक्ष्यों को अपना लेगा.
  • किसी खास कन्वर्ज़न ऐक्शन को टारगेट करने वाले कैंपेन, कन्वर्ज़न मैनेजर खाते के डिफ़ॉल्ट कन्वर्ज़न लक्ष्यों का इस्तेमाल करने पर स्विच हो जाएंगे. किसी खास कन्वर्ज़न ऐक्शन को टारगेट करना जारी रखने पर, कैंपेन का परफ़ॉर्मेंस में उतार-चढ़ाव हो सकता है. ऐसा इसलिए, क्योंकि हो सकता है कि मैनेजर खाते के लक्ष्य, क्लाइंट खाते के लक्ष्यों से अलग हों. पक्का करें कि आपके कैंपेन सही लक्ष्यों के लिए ऑप्टिमाइज़ किए गए हों.
  • अगर कोई खाता एक से ज़्यादा मैनेजर खाते से जुड़ा है, तो वह सिर्फ़ एक मैनेजर खाते के कन्वर्ज़न ऐक्शन का इस्तेमाल कर सकता है. अगर कोई कन्वर्ज़न ट्रैकिंग खाता नहीं दिया गया है, तो खाता डिफ़ॉल्ट रूप से कन्वर्ज़न ट्रैकिंग खाते के तौर पर इस्तेमाल होगा.

कन्वर्ज़न ऐक्शन बनाएं

कन्वर्ज़न मेज़र करने के लिए, उस कन्वर्ज़न ऐक्शन के type के लिए ConversionAction सेट अप करें जिसे आपको ट्रैक करना है. उदाहरण के लिए, ऑनलाइन खरीदारी और फ़ोन कॉल के लिए अलग-अलग कन्वर्ज़न ऐक्शन की ज़रूरत होती है.

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

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

कोड का उदाहरण

नीचे दिए गए कोड के उदाहरण में, नया कन्वर्ज़न ऐक्शन बनाने की प्रोसेस के बारे में बताया गया है. खास तौर पर, यह type को UPLOAD_CLICKS पर सेट करके एक कन्वर्ज़न ऐक्शन बनाता है. यह category को DEFAULT पर भी सेट करता है.

ये डिफ़ॉल्ट सेटिंग लागू होती हैं:

Java

private void runExample(GoogleAdsClient googleAdsClient, long customerId) {

  // Creates a ConversionAction.
  ConversionAction conversionAction =
      ConversionAction.newBuilder()
          // Note that conversion action names must be unique. If a conversion action already
          // exists with the specified conversion_action_name the create operation will fail with
          // a ConversionActionError.DUPLICATE_NAME error.
          .setName("Earth to Mars Cruises Conversion #" + getPrintableDateTime())
          .setCategory(ConversionActionCategory.DEFAULT)
          .setType(ConversionActionType.WEBPAGE)
          .setStatus(ConversionActionStatus.ENABLED)
          .setViewThroughLookbackWindowDays(15L)
          .setValueSettings(
              ValueSettings.newBuilder()
                  .setDefaultValue(23.41)
                  .setAlwaysUseDefaultValue(true)
                  .build())
          .build();

  // Creates the operation.
  ConversionActionOperation operation =
      ConversionActionOperation.newBuilder().setCreate(conversionAction).build();

  try (ConversionActionServiceClient conversionActionServiceClient =
      googleAdsClient.getLatestVersion().createConversionActionServiceClient()) {
    MutateConversionActionsResponse response =
        conversionActionServiceClient.mutateConversionActions(
            Long.toString(customerId), Collections.singletonList(operation));
    System.out.printf("Added %d conversion actions:%n", response.getResultsCount());
    for (MutateConversionActionResult result : response.getResultsList()) {
      System.out.printf(
          "New conversion action added with resource name: '%s'%n", result.getResourceName());
    }
  }
}
      

C#

public void Run(GoogleAdsClient client, long customerId)
{
    // Get the ConversionActionService.
    ConversionActionServiceClient conversionActionService =
        client.GetService(Services.V20.ConversionActionService);

    // Note that conversion action names must be unique.
    // If a conversion action already exists with the specified name the create operation
    // will fail with a ConversionAction.DUPLICATE_NAME error.
    string ConversionActionName = "Earth to Mars Cruises Conversion #"
        + ExampleUtilities.GetRandomString();

    // Add a conversion action.
    ConversionAction conversionAction = new ConversionAction()
    {
        Name = ConversionActionName,
        Category = ConversionActionCategory.Default,
        Type = ConversionActionType.Webpage,
        Status = ConversionActionStatus.Enabled,
        ViewThroughLookbackWindowDays = 15,
        ValueSettings = new ConversionAction.Types.ValueSettings()
        {
            DefaultValue = 23.41,
            AlwaysUseDefaultValue = true
        }
    };

    // Create the operation.
    ConversionActionOperation operation = new ConversionActionOperation()
    {
        Create = conversionAction
    };

    try
    {
        // Create the conversion action.
        MutateConversionActionsResponse response =
            conversionActionService.MutateConversionActions(customerId.ToString(),
                    new ConversionActionOperation[] { operation });

        // Display the results.
        foreach (MutateConversionActionResult newConversionAction in response.Results)
        {
            Console.WriteLine($"New conversion action with resource name = " +
                $"'{newConversionAction.ResourceName}' was added.");
        }
    }
    catch (GoogleAdsException e)
    {
        Console.WriteLine("Failure:");
        Console.WriteLine($"Message: {e.Message}");
        Console.WriteLine($"Failure: {e.Failure}");
        Console.WriteLine($"Request ID: {e.RequestId}");
        throw;
    }
}
      

PHP

public static function runExample(GoogleAdsClient $googleAdsClient, int $customerId)
{
    // Creates a conversion action.
    $conversionAction = new ConversionAction([
        // Note that conversion action names must be unique.
        // If a conversion action already exists with the specified conversion_action_name
        // the create operation will fail with a ConversionActionError.DUPLICATE_NAME error.
        'name' => 'Earth to Mars Cruises Conversion #' . Helper::getPrintableDatetime(),
        'category' => ConversionActionCategory::PBDEFAULT,
        'type' => ConversionActionType::WEBPAGE,
        'status' => ConversionActionStatus::ENABLED,
        'view_through_lookback_window_days' => 15,
        'value_settings' => new ValueSettings([
            'default_value' => 23.41,
            'always_use_default_value' => true
        ])
    ]);

    // Creates a conversion action operation.
    $conversionActionOperation = new ConversionActionOperation();
    $conversionActionOperation->setCreate($conversionAction);

    // Issues a mutate request to add the conversion action.
    $conversionActionServiceClient = $googleAdsClient->getConversionActionServiceClient();
    $response = $conversionActionServiceClient->mutateConversionActions(
        MutateConversionActionsRequest::build($customerId, [$conversionActionOperation])
    );

    printf("Added %d conversion actions:%s", $response->getResults()->count(), PHP_EOL);

    foreach ($response->getResults() as $addedConversionAction) {
        /** @var ConversionAction $addedConversionAction */
        printf(
            "New conversion action added with resource name: '%s'%s",
            $addedConversionAction->getResourceName(),
            PHP_EOL
        );
    }
}
      

Python

def main(client, customer_id):
    conversion_action_service = client.get_service("ConversionActionService")

    # Create the operation.
    conversion_action_operation = client.get_type("ConversionActionOperation")

    # Create conversion action.
    conversion_action = conversion_action_operation.create

    # Note that conversion action names must be unique. If a conversion action
    # already exists with the specified conversion_action_name, the create
    # operation will fail with a ConversionActionError.DUPLICATE_NAME error.
    conversion_action.name = f"Earth to Mars Cruises Conversion {uuid.uuid4()}"
    conversion_action.type_ = (
        client.enums.ConversionActionTypeEnum.UPLOAD_CLICKS
    )
    conversion_action.category = (
        client.enums.ConversionActionCategoryEnum.DEFAULT
    )
    conversion_action.status = client.enums.ConversionActionStatusEnum.ENABLED
    conversion_action.view_through_lookback_window_days = 15

    # Create a value settings object.
    value_settings = conversion_action.value_settings
    value_settings.default_value = 15.0
    value_settings.always_use_default_value = True

    # Add the conversion action.
    conversion_action_response = (
        conversion_action_service.mutate_conversion_actions(
            customer_id=customer_id,
            operations=[conversion_action_operation],
        )
    )

    print(
        "Created conversion action "
        f'"{conversion_action_response.results[0].resource_name}".'
    )
      

Ruby

def add_conversion_action(customer_id)
  # GoogleAdsClient will read a config file from
  # ENV['HOME']/google_ads_config.rb when called without parameters
  client = Google::Ads::GoogleAds::GoogleAdsClient.new


  # Add a conversion action.
  conversion_action = client.resource.conversion_action do |ca|
    ca.name = "Earth to Mars Cruises Conversion #{(Time.new.to_f * 100).to_i}"
    ca.type = :UPLOAD_CLICKS
    ca.category = :DEFAULT
    ca.status = :ENABLED
    ca.view_through_lookback_window_days = 15

    # Create a value settings object.
    ca.value_settings = client.resource.value_settings do |vs|
      vs.default_value = 15
      vs.always_use_default_value = true
    end
  end

  # Create the operation.
  conversion_action_operation = client.operation.create_resource.conversion_action(conversion_action)

  # Add the ad group ad.
  response = client.service.conversion_action.mutate_conversion_actions(
    customer_id: customer_id,
    operations: [conversion_action_operation],
  )

  puts "New conversion action with resource name = #{response.results.first.resource_name}."
end
      

Perl

sub add_conversion_action {
  my ($api_client, $customer_id) = @_;

  # Note that conversion action names must be unique.
  # If a conversion action already exists with the specified conversion_action_name,
  # the create operation fails with error ConversionActionError.DUPLICATE_NAME.
  my $conversion_action_name = "Earth to Mars Cruises Conversion #" . uniqid();

  # Create a conversion action.
  my $conversion_action =
    Google::Ads::GoogleAds::V20::Resources::ConversionAction->new({
      name                          => $conversion_action_name,
      category                      => DEFAULT,
      type                          => WEBPAGE,
      status                        => ENABLED,
      viewThroughLookbackWindowDays => 15,
      valueSettings                 =>
        Google::Ads::GoogleAds::V20::Resources::ValueSettings->new({
          defaultValue          => 23.41,
          alwaysUseDefaultValue => "true"
        })});

  # Create a conversion action operation.
  my $conversion_action_operation =
    Google::Ads::GoogleAds::V20::Services::ConversionActionService::ConversionActionOperation
    ->new({create => $conversion_action});

  # Add the conversion action.
  my $conversion_actions_response =
    $api_client->ConversionActionService()->mutate({
      customerId => $customer_id,
      operations => [$conversion_action_operation]});

  printf "New conversion action added with resource name: '%s'.\n",
    $conversion_actions_response->{results}[0]{resourceName};

  return 1;
}
      

इस उदाहरण को अपनी क्लाइंट लाइब्रेरी के रीमार्केटिंग फ़ोल्डर और कोड के उदाहरणों के कलेक्शन में देखा जा सकता है: कन्वर्ज़न ऐक्शन कोड का उदाहरण जोड़ें.

पुष्टि

Google Ads और Google Ads API, कई तरह के कन्वर्ज़न ऐक्शन के साथ काम करते हैं. इसलिए, पुष्टि करने के कुछ नियम, ऐक्शन के type के आधार पर अलग-अलग होते हैं.

कन्वर्ज़न ऐक्शन बनाते समय, अब तक सबसे ज़्यादा होने वाली गड़बड़ी DUPLICATE_NAME है. पक्का करें कि आपने हर कन्वर्ज़न ऐक्शन के लिए, यूनीक नाम का इस्तेमाल किया हो.

ConversionAction फ़ील्ड सेट करने के लिए, यहां कुछ सलाह दी गई हैं:

सभी एनम फ़ील्ड
किसी भी एनम फ़ील्ड को UNKNOWN पर सेट करने की कोशिश करने पर, RequestError.INVALID_ENUM_VALUE गड़बड़ी का मैसेज दिखता है.
app_id
app_id एट्रिब्यूट में बदलाव नहीं किया जा सकता. इसे सिर्फ़ नया ऐप्लिकेशन कन्वर्ज़न बनाते समय सेट किया जा सकता है.
attribution_model_settings
इस विकल्प को अब इस्तेमाल न किए जाने वाले विकल्प पर सेट करने पर, CANNOT_SET_RULE_BASED_ATTRIBUTION_MODELS वाली गड़बड़ी दिखती है. Google Ads सिर्फ़ GOOGLE_ADS_LAST_CLICK और GOOGLE_SEARCH_ATTRIBUTION_DATA_DRIVEN के साथ काम करता है.
click_through_lookback_window_days

इस एट्रिब्यूट की वैल्यू को तय की गई सीमा से बाहर की वैल्यू पर सेट करने पर, RangeError.TOO_LOW या RangeError.TOO_HIGH गड़बड़ी का मैसेज दिखता है.

यह एट्रिब्यूट, AD_CALL या WEBSITE_CALL कन्वर्ज़न ऐक्शन के लिए [1,60] की रेंज में होना चाहिए. ज़्यादातर अन्य कन्वर्ज़न ऐक्शन के लिए, अनुमति वाली रेंज [1,30] है.

include_in_conversions_metric

create या update ऑपरेशन में इस वैल्यू को सेट करने पर, FieldError.IMMUTABLE_FIELD गड़बड़ी का मैसेज दिखता है. इसके बजाय, primary_for_goal को कन्वर्ज़न लक्ष्यों की गाइड में बताए गए तरीके से सेट करें.

phone_call_duration_seconds

कॉल के लिए न बनाए गए कन्वर्ज़न ऐक्शन पर इस एट्रिब्यूट को सेट करने की कोशिश करने पर, FieldError.VALUE_MUST_BE_UNSET गड़बड़ी का मैसेज दिखता है.

type

type एट्रिब्यूट में बदलाव नहीं किया जा सकता. इसे सिर्फ़ नया कन्वर्ज़न बनाते समय सेट किया जा सकता है.

type को UNKNOWN के बराबर करके कन्वर्ज़न ऐक्शन को अपडेट करने पर, MutateError.MUTATE_NOT_ALLOWED गड़बड़ी दिखती है.

value_settings

WEBSITE_CALL या AD_CALL कन्वर्ज़न ऐक्शन के लिए, value_settings में always_use_default_value को true पर सेट करना ज़रूरी है. इस वैल्यू को बनाते या अपडेट करते समय false की वैल्यू डालने पर, INVALID_VALUE गड़बड़ी दिखती है.

view_through_lookback_window_days

इस एट्रिब्यूट की वैल्यू को तय की गई सीमा से बाहर की वैल्यू पर सेट करने पर, RangeError.TOO_LOW या RangeError.TOO_HIGH गड़बड़ी का मैसेज दिखता है. ज़्यादातर कन्वर्ज़न ऐक्शन के लिए, [1,30] की रेंज तय की जा सकती है.

इस एट्रिब्यूट को AD_CALL या WEBSITE_CALL कन्वर्ज़न ऐक्शन पर सेट नहीं किया जा सकता. वैल्यू डालने पर, VALUE_MUST_BE_UNSET गड़बड़ी का मैसेज दिखता है.