يجب تفعيل ميزة "تتبُّع الإحالات الناجحة" في حساب الإحالات الناجحة على "إعلانات Google" لتسجيل الإحالات الناجحة. يقدّم هذا الدليل تفاصيل حول كيفية التأكّد ممّا إذا كانت ميزة "تتبُّع الإحالات الناجحة" مفعّلة، وتفعيلها إذا لم تكن مفعّلة بعد، واسترداد معلومات عن إجراءات الإحالات الناجحة الحالية.
تتطلّب معظم إجراءات الإحالات الناجحة أيضًا اتّخاذ خطوات إضافية من جانبك لتتبُّعها. لمزيد من المعلومات عن أنواع إجراءات الإحالات الناجحة المختلفة ومتطلباتها، يُرجى الاطّلاع على دليل إنشاء إجراءات إحالات ناجحة.
الاستعداد لتقديم الموافقة
من المهم التأكّد من أنّ لديك إذنًا بمشاركة بيانات الإحالات الناجحة مع Google. يمكنك تنفيذ هذه الخطوة باتّباع إحدى الطريقتين التاليتين:
- ضبط إعدادات الموافقة التلقائية على مستوى الحساب. في واجهة مستخدِم "إعلانات Google"، انقر على الأدوات - > إدارة بيانات إعلانات Google -> إعدادات الموافقة -> إعدادات الموافقة التلقائية.
- ضبط حقل ClickConversion.consent في كل إحالة ناجحة مستورَدة.
إعداد موقعك الإلكتروني لتتبُّع الإحالات الناجحة
إذا كنت بصدد بدء عملية دمج استيراد الإحالات الناجحة غير الإلكترونية، فإنّ الخطوة الأولى هي اتّباع الخطوات الواردة في دليل ضبط علامة تتبُّع من Google لميزة "الإحالات الناجحة المحسّنة للعملاء المهتمين" لضبط موقعك الإلكتروني لتتبُّع ميزة "الإحالات الناجحة المحسّنة للعملاء المهتمين". يمكنك أيضًا استخدام Google Tag Manager لضبط موقعك الإلكتروني باتّباع الخطوات الواردة في دليل ضبط Google Tag Manager لميزة "الإحالات الناجحة المحسّنة للعملاء المهتمين".
تفعيل ميزة "تتبُّع الإحالات الناجحة" في حساب الإحالات الناجحة على "إعلانات Google"
استرداد معلومات عن إعداد ميزة "تتبُّع الإحالات الناجحة"
يمكنك التحقّق من إعداد ميزة "تتبُّع الإحالات الناجحة" في حسابك والتأكّد من تفعيلها من خلال طلب 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" الذي ينشئ الإحالات الناجحة لهذا العميل ويديرها. بالنسبة إلى العملاء الذين يستخدمون
ميزة "تتبُّع الإحالات الناجحة في جميع الحسابات"،
يكون هذا هو رقم تعريف حساب إداري. يجب تقديم رقم تعريف عميل الإحالات الناجحة على "إعلانات Google" على أنّه customer_id في طلبات Google Ads API لإنشاء الإحالات الناجحة وإدارتها.
يُرجى العِلم بأنّه تتم تعبئة هذا الحقل حتى إذا لم تكن ميزة "تتبُّع الإحالات الناجحة" مفعّلة.
يشير الحقل
conversion_tracking_status
إلى ما إذا كانت ميزة "تتبُّع الإحالات الناجحة" مفعّلة وما إذا كان الحساب
يستخدم ميزة "تتبُّع الإحالات الناجحة في جميع الحسابات".
إنشاء إجراء إحالة ناجحة ضمن عميل الإحالات الناجحة على "إعلانات Google"
إذا كانت قيمة conversion_tracking_status هي NOT_CONVERSION_TRACKED، فهذا يعني أنّ ميزة "تتبُّع الإحالات الناجحة" غير مفعّلة للحساب. فعِّل ميزة "تتبُّع الإحالات الناجحة"
من خلال إنشاء إجراء واحد على الأقل ConversionAction في
حساب الإحالات الناجحة على "إعلانات Google"، كما في المثال التالي. بدلاً من ذلك، يمكنك إنشاء إجراء إحالة ناجحة في واجهة المستخدِم باتّباع التعليمات الواردة في مركز المساعدة لنوع الإحالة الناجحة الذي تريد تفعيله.
يُرجى العِلم بأنّه يتم تفعيل ميزة "الإحالات الناجحة المحسّنة" تلقائيًا عند إرسالها من خلال Google Ads API، ولكن يمكن إيقافها من خلال واجهة مستخدِم "إعلانات Google".
مثال على الرمز البرمجي
جافا
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"
الذي حدّدته أعلاه، وضبط نوع إجراء الإحالة الناجحة على القيمة
الصحيحة
ConversionActionType.
SELECT
conversion_action.resource_name,
conversion_action.name,
conversion_action.status
FROM conversion_action
WHERE conversion_action.type = 'INSERT_CONVERSION_ACTION_TYPE'
تتبّع الإحالات الناجحة في جميع الحسابات
تسمح ميزة "تتبُّع الإحالات الناجحة في جميع الحسابات" لحسابات "إعلانات Google" باستيراد الإحالات الناجحة نيابةً عن حسابات أخرى، ربّما تكون قد عرضت الإعلانات التي أدّت إلى تحقيق الإحالات الناجحة. يمكن أن يساعد ذلك في تبسيط عملية الدمج من خلال السماح لك بدمج الحسابات التي تقدّم طلبات الاستيراد.
تفعيل ميزة "تتبُّع الإحالات الناجحة في جميع الحسابات" في Google Ads API
يمكنك استخدام Google Ads API لتفعيل ميزة "تتبُّع الإحالات الناجحة في جميع الحسابات" عند إنشاء حسابات عملاء أو تعديلها.
في مورد Customer، اضبط حقل
conversion_tracking_setting.google_ads_conversion_customer
على
اسم مورد الحساب الإداري الذي يجب أن يدير إجراءات الإحالات الناجحة نيابةً عن حساب العميل.
يجب أن يتم إرسال الطلبات التي تعدِّل عميل الإحالات الناجحة لحساب عميل من قِبل الحساب الإداري الذي سيصبح عميل الإحالات الناجحة الجديد للعميل. يمكنك تنفيذ ذلك من خلال ضبط login-customer-id على رقم تعريف الحساب الإداري.
- سيتبنّى حساب العميل قواعد قيمة الإحالة الناجحة التلقائية وأهداف مراحل نشاط العملاء التلقائية لمدير تتبُّع الإحالات الناجحة الجديد.
- سيتم تبديل الحملات التي تستهدِف إجراء إحالة ناجحة محدّدًا إلى استخدام أهداف الإحالات الناجحة التلقائية لحساب مدير الإحالات الناجحة. وإذا تمت مواصلة استهداف إجراء إحالة ناجحة محدّد، قد يؤدي ذلك إلى سلوك غير متّسق، لأنّ الحساب الإداري قد لا تكون له الأهداف نفسها التي يستخدِمها حساب العميل. تأكَّد من تحسين حملاتك لتحقيق الأهداف الصحيحة.
- إذا كان أحد الحسابات ينتمي إلى أكثر من حساب إداري، يمكنه فقط استخدام إجراءات الإحالات الناجحة من حساب إداري واحد. إذا لم يتم تحديد حساب لتتبُّع الإحالات الناجحة، سيستخدم الحساب نفسه كحساب لتتبُّع الإحالات الناجحة تلقائيًا.
استيراد الإحالات الناجحة في جميع الحسابات
عند تفعيل ميزة "تتبُّع الإحالات الناجحة في جميع الحسابات"، يمكن لحسابات العملاء والحسابات الإدارية استيراد الإحالات الناجحة نيابةً عن حساب عرض الإعلانات. يُسهّل ذلك منطق الاستيراد بحيث لا تحتاج إلى تحديد حساب عرض الإعلانات لكل إحالة ناجحة في وقت الاستيراد، بل يمكنك فقط اختيار حساب واحد من شجرة حسابك لاستيراد جميع الإحالات الناجحة.
لتحميل إحالة ناجحة بنجاح، يجب أن يتمكّن حساب التحميل من الوصول إلى إجراء الإحالة الناجحة. في التسلسل الهرمي لميزة "تتبُّع الإحالات الناجحة في جميع الحسابات"، يمكن لحساب التحميل الوصول إلى الإجراء إذا كان حسابًا رئيسيًا (إداريًا) أو حسابًا فرعيًا لمالك إجراء الإحالة الناجحة في شجرة الحساب.
يوضّح المخطّط البياني التالي بنية التفويض لاستيراد الإحالات الناجحة. في هذا الرسم، C1 هو حساب العميل الذي عرض الإعلان الذي أدّى إلى تحقيق الإحالة الناجحة، وM2 هو مالك إجراء الإحالة الناجحة والحساب الرئيسي لتتبُّع الإحالات الناجحة في C1. يُسمح للحسابات المميّزة باللون الأخضر باستيراد الإحالات الناجحة نيابةً عن C1، بينما لا يمكن للحسابات المميّزة باللون الأحمر فعل ذلك.

يجب إنشاء إجراءات إحالات ناجحة
لقياس الإحالات الناجحة، عليك إعداد
ConversionAction لنوع
type إجراء
الإحالة الناجحة الذي تريد تتبُّعه. على سبيل المثال، تتطلّب عملية الشراء على الإنترنت ومكالمة هاتفية إجراءَي إحالة ناجحة مختلفَين.
أفضل طريقة لإعداد إجراءات إحالات ناجحة جديدة في واجهة برمجة التطبيقات هي استخدام
مثال الرمز البرمجي "إضافة إجراء إحالة ناجحة" أدناه. يتولّى المثال جميع مهام المصادقة في الخلفية نيابةً عنك، ويرشدك خلال عملية إنشاء ConversionAction.
تتطلّب معظم إجراءات الإحالات الناجحة أيضًا اتّخاذ خطوات إضافية من جانبك لتتبُّعها. على سبيل المثال، لتتبُّع الإحالات الناجحة على موقعك الإلكتروني، يجب إضافة مقتطف رمز يُعرف باسم العلامة إلى صفحة الإحالة الناجحة على موقعك الإلكتروني. للاطّلاع على المتطلبات التفصيلية لأنواع إجراءات الإحالات الناجحة الأخرى ، يُرجى الاطّلاع على مقالة "مركز المساعدة" .
إذا كنت تستخدم ميزة "تتبُّع الإحالات الناجحة في جميع الحسابات
"، تعرض
ConversionActionService إجراءات الإحالات الناجحة التالية:
- جميع إجراءات الإحالات الناجحة التي يحدّدها الحساب الإداري الذي يستخدمه الحساب لتتبُّع الإحالات الناجحة في جميع الحسابات
- جميع إجراءات الإحالات الناجحة التي سجّل العميل إحصاءات عنها، بما في ذلك الإجراءات التي يحدّدها النظام والإجراءات التي يملكها المدير حتى إذا ألغى المدير ربط الحساب لاحقًا
- جميع الإجراءات التي حدّدها العميل في حسابه الخاص
- الإحالات الناجحة في "إحصاءات Google" التي تم إنشاؤها في مواقع "إحصاءات Google" المرتبطة.
ويشمل ذلك إجراءات الإحالات الناجحة في "إحصاءات Google" التي لم يتم استيرادها إلى "إعلانات Google"،
والتي تكون حالتها
HIDDEN.
مثال على الرمز البرمجي
يرشدك مثال الرمز البرمجي التالي خلال عملية إنشاء إجراء إحالة ناجحة جديد. على وجه التحديد، ينشئ هذا المثال إجراء إحالة ناجحة يكون
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. يُرجى الاطّلاع على مقالة مركز المساعدة هذه لمعرفة المزيد عن نماذج الإحالة.
جافا
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" و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" سوىGOOGLE_ADS_LAST_CLICKوGOOGLE_SEARCH_ATTRIBUTION_DATA_DRIVEN. click_through_lookback_window_daysيؤدي ضبط هذه السمة على قيمة خارج النطاق المسموح به إلى ظهور الخطأ
RangeError.TOO_LOWأوRangeError.TOO_HIGH.يجب أن تكون هذه السمة في النطاق
[1,60]لإجراء الإحالة الناجحةAD_CALLأوWEBSITE_CALL. بالنسبة إلى معظم إجراءات الإحالات الناجحة الأخرى، يكون النطاق المسموح به هو[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يجب أن يكون
value_settingsلإجراء الإحالة الناجحةWEBSITE_CALLأوAD_CALLمضبوطًا على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.