कन्वर्ज़न रिकॉर्ड करने के लिए, आपको अपने 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.V21.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::V21::Resources::ConversionAction->new({ name => $conversion_action_name, category => DEFAULT, type => WEBPAGE, status => ENABLED, viewThroughLookbackWindowDays => 15, valueSettings => Google::Ads::GoogleAds::V21::Resources::ValueSettings->new({ defaultValue => 23.41, alwaysUseDefaultValue => "true" })}); # Create a conversion action operation. my $conversion_action_operation = Google::Ads::GoogleAds::V21::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 कन्वर्ज़न.
इसमें Google Ads में इंपोर्ट नहीं किए गए Analytics कन्वर्ज़न के लिए कार्रवाइयां शामिल हैं. इनका स्टेटस
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
अनुरोध
भेजने वाला खाता भी होना चाहिए.
ध्यान दें: 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
फ़ील्ड कोAttributionModel
कीGOOGLE_SEARCH_ATTRIBUTION_DATA_DRIVEN
वैल्यू पर सेट करता है. एट्रिब्यूशन मॉडल के बारे में ज़्यादा जानने के लिए, सहायता केंद्र का यह लेख पढ़ें.
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.V21.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::V21::Resources::ConversionAction->new({ name => $conversion_action_name, category => DEFAULT, type => WEBPAGE, status => ENABLED, viewThroughLookbackWindowDays => 15, valueSettings => Google::Ads::GoogleAds::V21::Resources::ValueSettings->new({ defaultValue => 23.41, alwaysUseDefaultValue => "true" })}); # Create a conversion action operation. my $conversion_action_operation = Google::Ads::GoogleAds::V21::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
फ़ील्ड सेट करने के बारे में यहां कुछ सुझाव दिए गए हैं:
- सभी enum फ़ील्ड
- किसी भी ईनम फ़ील्ड को
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
कोtrue
पर सेट किया जाना चाहिए.always_use_default_value
इस वैल्यू को बनाते या अपडेट करते समयfalse
वैल्यू डालने पर,INVALID_VALUE
गड़बड़ी होती है.view_through_lookback_window_days
इस एट्रिब्यूट को स्वीकार की गई सीमा से बाहर की वैल्यू पर सेट करने से,
RangeError.TOO_LOW
याRangeError.TOO_HIGH
गड़बड़ी होती है. ज़्यादातर कन्वर्ज़न ऐक्शन के लिए, मान्य सीमा[1,30]
है.इस एट्रिब्यूट को
AD_CALL
याWEBSITE_CALL
कन्वर्ज़न ऐक्शन पर सेट नहीं किया जा सकता. वैल्यू डालने पर,VALUE_MUST_BE_UNSET
गड़बड़ी होती है.