कन्वर्ज़न रिकॉर्ड करने के लिए, आपको अपने Google Ads कन्वर्ज़न खाते में कन्वर्ज़न ट्रैकिंग की सुविधा चालू करनी होगी. इस गाइड में, यह पुष्टि करने का तरीका बताया गया है कि कन्वर्ज़न ट्रैकिंग की सुविधा चालू है या नहीं. साथ ही, अगर यह सुविधा चालू नहीं है, तो इसे चालू करने और मौजूदा कन्वर्ज़न ऐक्शन के बारे में जानकारी पाने का तरीका भी बताया गया है.
ज़्यादातर कन्वर्ज़न ऐक्शन को ट्रैक करने के लिए, आपको कुछ अतिरिक्त चरण भी पूरे करने होंगे. कन्वर्ज़न ऐक्शन के अलग-अलग टाइप और उनकी ज़रूरी शर्तों के बारे में ज़्यादा जानने के लिए, कन्वर्ज़न ऐक्शन बनाना गाइड देखें.
सहमति देने की तैयारी करना
यह पक्का करना ज़रूरी है कि आपके पास Google के साथ कन्वर्ज़न डेटा शेयर करने की अनुमति हो. नीचे दिए गए दो तरीकों में से किसी भी एक से ऐसा किया जा सकता है:
- खाते के लेवल पर, डिफ़ॉल्ट सहमति सेटिंग कॉन्फ़िगर करना. Google Ads के यूज़र इंटरफ़ेस (यूआई) में, टूल -> डेटा मैनेजर -> सहमति सेटिंग -> डिफ़ॉल्ट सहमति सेटिंग पर क्लिक करें.
- इंपोर्ट किए गए हर कन्वर्ज़न के लिए, ClickConversion.consent फ़ील्ड सेट करना.
कन्वर्ज़न ट्रैक करने के लिए अपनी वेबसाइट सेट अप करना
अगर ऑफ़लाइन कन्वर्ज़न इंपोर्ट इंटिग्रेशन शुरू किया जा रहा है, तो पहला चरण यह है कि अपनी वेबसाइट को लीड के लिए बेहतर कन्वर्ज़न ट्रैकिंग के साथ सेट अप किया जाए. इसके लिए, लीड के लिए बेहतर कन्वर्ज़न ट्रैकिंग के लिए Google टैग कॉन्फ़िगर करना गाइड में दिए गए चरणों का पालन करें. Google Tag Manager का इस्तेमाल करके भी अपनी वेबसाइट को कॉन्फ़िगर किया जा सकता है. इसके लिए, लीड के लिए बेहतर कन्वर्ज़न ट्रैकिंग के लिए Google Tag Manager कॉन्फ़िगर करना गाइड में दिए गए चरणों का पालन करें.
अपने Google Ads कन्वर्ज़न खाते में कन्वर्ज़न ट्रैकिंग की सुविधा चालू करना
कन्वर्ज़न ट्रैकिंग सेटअप के बारे में जानकारी पाना
`Customer` संसाधन के लिए `ConversionTrackingSetting` क्वेरी करके, अपने खाते के कन्वर्ज़न ट्रैकिंग सेटअप की जांच की जा सकती है. साथ ही, यह पुष्टि की जा सकती है कि कन्वर्ज़न
ट्रैकिंग की सुविधा चालू है या नहीं.
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 API के अनुरोधों में Google Ads कन्वर्ज़न ग्राहक आईडी को customer_id के तौर पर दिया जाना चाहिए.
ध्यान दें कि यह फ़ील्ड तब भी भर जाता है, जब कन्वर्ज़न ट्रैकिंग की सुविधा चालू न हो.
The
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.V24.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: GoogleAdsClient, customer_id: str) -> None: conversion_action_service: ConversionActionServiceClient = ( client.get_service("ConversionActionService") ) # Create the operation. conversion_action_operation: ConversionActionOperation = client.get_type( "ConversionActionOperation" ) # Create conversion action. conversion_action: ConversionAction = 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: ConversionAction.ValueSettings = ( conversion_action.value_settings ) value_settings.default_value = 15.0 value_settings.always_use_default_value = True # Add the conversion action. conversion_action_response: MutateConversionActionsResponse = ( 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::V24::Resources::ConversionAction->new({ name => $conversion_action_name, category => DEFAULT, type => WEBPAGE, status => ENABLED, viewThroughLookbackWindowDays => 15, valueSettings => Google::Ads::GoogleAds::V24::Resources::ValueSettings->new({ defaultValue => 23.41, alwaysUseDefaultValue => "true" })}); # Create a conversion action operation. my $conversion_action_operation = Google::Ads::GoogleAds::V24::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; }
curl
पक्का करें कि 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.
क्लाइंट खाते बनाते समय, क्रॉस-कन्वर्ज़न ट्रैकिंग को ऑप्ट-इन करने के लिए, Google Ads API का इस्तेमाल किया जा सकता है.
नया Customer बनाते समय, conversion_tracking_setting.google_ads_conversion_customer
को उस
संसाधन नाम वाले मैनेजर
खाते पर सेट करें जिसे क्लाइंट खाते की ओर से कन्वर्ज़न ऐक्शन मैनेज करने चाहिए.
यह मैनेजर खाता, नए क्लाइंट खाते के लिए create अनुरोध जारी करने वाला खाता भी होना चाहिए.
क्लाइंट खाते बनाते और अपडेट करते समय, दोनों ही स्थितियों में क्रॉस-कन्वर्ज़न ट्रैकिंग को ऑप्ट-इन करने के लिए, Google Ads API का इस्तेमाल किया जा सकता है.
मौजूदा क्लाइंट खाते को अपडेट करते समय, क्रॉस-खाता
कन्वर्ज़न ट्रैकिंग को ऑप्ट-इन किया जा सकता है. इसके लिए,
conversion_tracking_setting.google_ads_conversion_customer
फ़ील्ड सेट करें. इस फ़ील्ड को उस
संसाधन के नाम पर सेट किया जाना चाहिए जिसे क्लाइंट खाते की ओर से कन्वर्ज़न ऐक्शन मैनेज करने चाहिए.
यह मैनेजर खाता, क्लाइंट खाते के लिए update अनुरोध जारी करने वाला खाता भी होना चाहिए.
ध्यान दें: Google Ads API का इस्तेमाल करके, क्लाइंट खाते की क्रॉस-खाता कन्वर्ज़न ट्रैकिंग सेटिंग में बदलाव करने की सुविधा, सिर्फ़ उन खातों के लिए उपलब्ध है जिन्हें इसकी अनुमति मिली हुई है. इसका इस्तेमाल करने के लिए, अपने खाता मैनेजर से संपर्क करें.
क्रॉस-खाता कन्वर्ज़न ट्रैकिंग को ऑप्ट-इन करने या मौजूदा क्लाइंट खाते के लिए कन्वर्ज़न ट्रैकिंग मैनेजर को बदलने पर, वही चेतावनियां लागू होती हैं जो यूज़र इंटरफ़ेस (यूआई) में यह बदलाव करने पर लागू होती हैं. खास तौर पर, इस बारे में जानकारी मिलती है:
- क्लाइंट खाता, डिफ़ॉल्ट कन्वर्ज़न वैल्यू के नियमों और अपने नए कन्वर्ज़न ट्रैकिंग मैनेजर के डिफ़ॉल्ट ग्राहक लाइफ़साइकल लक्ष्यों को अपनाएगा.
- किसी खास कन्वर्ज़न ऐक्शन को टारगेट करने वाले कैंपेन, कन्वर्ज़न मैनेजर खाते के डिफ़ॉल्ट कन्वर्ज़न लक्ष्यों का इस्तेमाल करने लगेंगे. अगर किसी खास कन्वर्ज़न ऐक्शन को लगातार टारगेट किया जाता है, तो हो सकता है कि परफ़ॉर्मेंस में अंतर दिखे. इसकी वजह यह है कि शायद मैनेजर खाते के लक्ष्य, क्लाइंट खाते के लक्ष्यों से अलग हों. पक्का करें कि आपके कैंपेन, सही लक्ष्यों के हिसाब से ऑप्टिमाइज़ किए गए हों.
- अगर कोई खाता एक से ज़्यादा मैनेजर खाते से संबंधित है, तो वह सिर्फ़ एक मैनेजर खाते के कन्वर्ज़न ऐक्शन का इस्तेमाल कर सकता है. अगर कन्वर्ज़न ट्रैकिंग के लिए कोई खाता तय नहीं किया जाता है, तो खाता डिफ़ॉल्ट रूप से खुद को कन्वर्ज़न ट्रैकिंग खाते के तौर पर इस्तेमाल करेगा.
कन्वर्ज़न ऐक्शन बनाएं
कन्वर्ज़न मेज़र करने के लिए, उस कन्वर्ज़न ऐक्शन के
type के लिए
ConversionAction सेट अप करें जिसे ट्रैक करना है. उदाहरण के लिए, ऑनलाइन खरीदारी और फ़ोन कॉल के लिए अलग-अलग कन्वर्ज़न ऐक्शन की ज़रूरत होती है.
एपीआई में नए कन्वर्ज़न ऐक्शन सेट अप करने का सबसे अच्छा तरीका है कि नीचे दिए गए,
कन्वर्ज़न ऐक्शन जोड़ने के कोड के उदाहरण का इस्तेमाल किया जाए. इस सैंपल में, बैकग्राउंड में होने वाले सभी पुष्टि करने के टास्क आपके लिए मैनेज किए जाते हैं. साथ ही, इसमें
ConversionAction बनाने का तरीका भी बताया गया है.
ज़्यादातर कन्वर्ज़न ऐक्शन को ट्रैक करने के लिए, आपको कुछ अतिरिक्त चरण भी पूरे करने होंगे. उदाहरण के लिए, अपनी वेबसाइट पर होने वाले कन्वर्ज़न को ट्रैक करने के लिए, आपको अपनी वेबसाइट के कन्वर्ज़न पेज पर कोड स्निपेट जोड़ना होगा. इसे टैग कहा जाता है. कन्वर्ज़न ऐक्शन के अन्य टाइप की ज़रूरी शर्तों के बारे में ज़्यादा जानने के लिए, हमारे सहायता केंद्र का लेख देखें.
कोड का उदाहरण
यहां दिए गए कोड के उदाहरण में, नया कन्वर्ज़न ऐक्शन बनाने की प्रोसेस के बारे में बताया गया है. खास तौर पर, यह कन्वर्ज़न ऐक्शन बनाता है, जिसमें
type को
UPLOAD_CLICKS पर सेट किया जाता है.
यह category
को DEFAULT पर भी सेट करता है.
डिफ़ॉल्ट रूप से ये सेटिंग लागू होती हैं:
Google Ads API,
primary_for_goalफ़ील्ड को अपने-आप सेट करता है. हालांकि, इस फ़ील्ड को साफ़ तौर पर सेट किया जा सकता है, ताकि यह कंट्रोल किया जा सके कि कन्वर्ज़न लक्ष्यों के साथ मिलकर, कोई कन्वर्ज़न ऐक्शन आपके खाते में रिपोर्टिंग और बिडिंग पर कैसे असर डालता है.Google Ads API,
counting_typeको अपने-आपMANY_PER_CLICKपर सेट करता है. ज़्यादा जानकारी के लिए, कन्वर्ज़न की गिनती करने के विकल्पों के बारे में जानकारी देखें.Google Ads API, एट्रिब्यूशन मॉडल को डेटा ड्रिवन पर सेट करता है. इसके लिए,
attribution_model_settingsफ़ील्ड कोGOOGLE_SEARCH_ATTRIBUTION_DATA_DRIVENवैल्यू पर सेट किया जाता हैAttributionModel. एट्रिब्यूशन मॉडल के बारे में ज़्यादा जानने के लिए, सहायता केंद्र का यह लेख देखें.
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.V24.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: GoogleAdsClient, customer_id: str) -> None: conversion_action_service: ConversionActionServiceClient = ( client.get_service("ConversionActionService") ) # Create the operation. conversion_action_operation: ConversionActionOperation = client.get_type( "ConversionActionOperation" ) # Create conversion action. conversion_action: ConversionAction = 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: ConversionAction.ValueSettings = ( conversion_action.value_settings ) value_settings.default_value = 15.0 value_settings.always_use_default_value = True # Add the conversion action. conversion_action_response: MutateConversionActionsResponse = ( 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::V24::Resources::ConversionAction->new({ name => $conversion_action_name, category => DEFAULT, type => WEBPAGE, status => ENABLED, viewThroughLookbackWindowDays => 15, valueSettings => Google::Ads::GoogleAds::V24::Resources::ValueSettings->new({ defaultValue => 23.41, alwaysUseDefaultValue => "true" })}); # Create a conversion action operation. my $conversion_action_operation = Google::Ads::GoogleAds::V24::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; }
curl
यह उदाहरण, क्लाइंट लाइब्रेरी के रीमार्केटिंग फ़ोल्डर और कोड के उदाहरणों के कलेक्शन में देखा जा सकता है: कन्वर्ज़न ऐक्शन जोड़ने के कोड का उदाहरण.
पुष्टि
Google Ads और Google Ads API, कई तरह के कन्वर्ज़न ऐक्शन के साथ काम करते हैं. इसलिए, पुष्टि के कुछ
नियम, type
के हिसाब से अलग-अलग होते हैं.
कन्वर्ज़न ऐक्शन बनाते समय, सबसे आम गड़बड़ी
DUPLICATE_NAME होती है.
पक्का करें कि हर कन्वर्ज़न ऐक्शन के लिए, अलग-अलग नाम का इस्तेमाल किया जा रहा हो.
ConversionAction फ़ील्ड सेट करने के बारे में यहां कुछ सुझाव दिए गए हैं:
- सभी enum फ़ील्ड
- किसी भी enum फ़ील्ड को
UNKNOWNपर सेट करने की कोशिश करने पर,RequestError.INVALID_ENUM_VALUEगड़बड़ी होती है. app_id- यह
app_idएट्रिब्यूट में बदलाव नहीं किया जा सकता. इसे सिर्फ़ नया ऐप्लिकेशन कन्वर्ज़न बनाते समय सेट किया जा सकता है. attribution_model_settings- इसे बंद किए जा चुके विकल्प पर सेट करने पर,
CANNOT_SET_RULE_BASED_ATTRIBUTION_MODELSगड़बड़ी होती है. Google Ads सिर्फ़ click_through_lookback_window_daysइस एट्रिब्यूट को, अनुमति वाली रेंज से बाहर की वैल्यू पर सेट करने पर,
RangeError.TOO_LOWयाRangeError.TOO_HIGHगड़बड़ी होती है.AD_CALLयाWEBSITE_CALLकन्वर्ज़न ऐक्शन के लिए, इस एट्रिब्यूट की वैल्यू[1,60]के बीच होनी चाहिए. ज़्यादातर अन्य कन्वर्ज़न ऐक्शन के लिए, अनुमति वाली रेंज[1,30]है.include_in_conversions_metriccreateयाupdateकार्रवाई में इस वैल्यू को सेट करने पर,FieldError.IMMUTABLE_FIELDगड़बड़ी होती है. इसके बजाय, कन्वर्ज़न लक्ष्यों की गाइड में बताए गए तरीके से,primary_for_goalको सेट करें.phone_call_duration_secondsकॉल के लिए नहीं बने किसी कन्वर्ज़न ऐक्शन पर इस एट्रिब्यूट को सेट करने की कोशिश करने पर,
FieldError.VALUE_MUST_BE_UNSETगड़बड़ी होती है.typetypeएट्रिब्यूट में बदलाव नहीं किया जा सकता. इसे सिर्फ़ नया कन्वर्ज़न बनाते समय सेट किया जा सकता है.कन्वर्ज़न ऐक्शन को
typeपर सेट करके, अपडेट करने पर,MutateError.MUTATE_NOT_ALLOWEDगड़बड़ी होती है.UNKNOWNvalue_settingsWEBSITE_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गड़बड़ी होती है.
GOOGLE_ADS_LAST_CLICK और
GOOGLE_SEARCH_ATTRIBUTION_DATA_DRIVEN के साथ काम करता है.