ويقدّم هذا الدليل قائمة بالأنواع المختلفة لإجراءات الإحالات الناجحة التي يمكنك إنشاؤها باستخدام Google Ads API، ومعلومات عن كيفية ربطها بواجهة "إعلانات Google" على الويب، ومثال رمز مفصّل يوضّح كيفية إنشاء إجراءات إحالات ناجحة جديدة.
لقياس الإحالات الناجحة، عليك إعداد
ConversionAction
type
لإجراء الإحالة الناجحة الذي تريد تتبُّعه. على سبيل المثال، تتطلب عملية الشراء على الإنترنت وإجراء
مكالمة هاتفية إجراءات إحالة ناجحة مختلفة.
إنّ أفضل طريقة لإعداد إجراءات إحالات ناجحة جديدة في واجهة برمجة التطبيقات هي باستخدام
أدناه مثال على رمز إضافة إجراء الإحالة الناجحة. يعالج النموذج جميع مهام المصادقة في الخلفية نيابةً عنك، ويرشدك خلال إنشاء ConversionAction
.
تتطلب معظم إجراءات الإحالة الناجحة أيضًا خطوات إضافية من جانبك لتتبُّعها. على سبيل المثال، لتتبُّع الإحالات الناجحة على موقعك الإلكتروني، عليك إضافة مقتطف رمز يُسمى tag إلى صفحة الإحالات الناجحة في موقعك الإلكتروني. للاطّلاع على المتطلبات الأخرى لإجراءات الإحالات الناجحة، راجِع مقالة مركز المساعدة.
الإحالات الناجحة من الموقع الإلكتروني
تتيح لك الإحالات الناجحة للموقع الإلكتروني تتبُّع إجراءات الموقع الإلكتروني مثل المبيعات على الإنترنت والنقرات على الروابط ومشاهدات الصفحة وعمليات الاشتراك.
لتتبُّع الإحالات الناجحة في موقعك الإلكتروني، يجب إنشاء
ConversionAction
مع ضبط
ConversionActionType
على WEBPAGE
، وإضافة مقتطف رمز باسم علامة إلى صفحة الإحالات الناجحة في موقعك الإلكتروني.
وتشمل ConversionAction
عدة أنواع من الإحالات الناجحة للموقع الإلكتروني، ويتم تمييزها ضمن واجهة برمجة التطبيقات عن طريق الحقل type
في كل TagSnippet
مُدرَج في حقل
tag_snippets في ConversionAction
.
توفّر TagSnippet
رمز التتبّع الذي يجب تضمينه في موقعك الإلكتروني لتتبّع إجراءات الإحالات الناجحة.
تتطلّب الإحالات الناجحة للموقع الإلكتروني والنقر على رقم الهاتف
event_snippet
،
التي يجب وضعها على صفحات الويب التي تشير إلى إجراء إحالة ناجحة، مثل
صفحة تأكيد الدفع أو إرسال نموذج العملاء المحتملين، و
global_site_tag
،
التي يجب تثبيتها على كل صفحة من موقعك الإلكتروني. يمكنك استرداد هاتين السمتَين باستخدام ConversionActionService
. انتقِل إلى مركز المساعدة للحصول على مزيد من المعلومات حول كيفية وضع علامات على صفحاتك.
يعرض الجدول التالي معلمات واجهة برمجة التطبيقات المكافئة المراد استخدامها لكل مصدر في واجهة الويب لبرنامج "إعلانات Google":
نوع رمز التتبّع | مصدر "إعلانات Google" |
---|---|
WEBPAGE |
الموقع الإلكتروني والموقع الإلكتروني ("إحصاءات Google 4") |
WEBPAGE_ONCLICK |
الموقع الإلكتروني والموقع الإلكتروني ("إحصاءات Google 4") |
CLICK_TO_CALL |
نقرات رقم الهاتف |
--- |
الموقع الإلكتروني ("إحصاءات Google" (UA)) |
الإحالات الناجحة للتطبيق
تتيح لك الإحالة الناجحة للتطبيق تتبُّع عمليات تثبيت تطبيق الأجهزة الجوّالة أو عمليات الشراء داخل التطبيق من متجر Google Play.
يعرض الجدول التالي معلمات ConversionActionType
API المكافئة المطلوب استخدامها لكل مصدر في واجهة الويب لبرنامج "إعلانات Google":
نوع إجراء الإحالة الناجحة | مصدر "إعلانات Google" |
---|---|
GOOGLE_PLAY_DOWNLOAD |
Google Play > عمليات التثبيت |
GOOGLE_PLAY_IN_APP_PURCHASE |
Google Play > عمليات الشراء داخل التطبيق |
إذا كنت تريد تتبُّع إجراءات أخرى لتطبيقات الأجهزة الجوّالة باستخدام مواقع "إحصاءات Google 4" أو إحصاءات التطبيقات التابعة لجهات خارجية. راجِع أنواع إجراءات الإحالات الناجحة الإضافية.
الإحالات الناجحة للمكالمات الهاتفية
تتيح لك ميزة تتبُّع الإحالات الناجحة للمكالمات الهاتفية تتبُّع المكالمات من الإعلانات والمكالمات إلى رقم على موقعك الإلكتروني والنقرات على الأرقام في المواقع الإلكترونية المتوافقة مع الأجهزة الجوّالة.
يعرض الجدول التالي معلمات ConversionActionType
API المكافئة المطلوب استخدامها لكل مصدر في واجهة الويب لبرنامج "إعلانات Google":
نوع إجراء الإحالة الناجحة | مصدر "إعلانات Google" |
---|---|
AD_CALL |
المكالمات من الإعلانات التي تستخدم إضافات المكالمات أو الإعلانات للاتصال فقط |
WEBSITE_CALL |
المكالمات الواردة إلى رقم هاتف مُدرَج في موقعك الإلكتروني |
CLICK_TO_CALL |
النقرات التي يتم إجراؤها على رقم في موقعك الإلكتروني المتوافق مع الأجهزة الجوّالة |
يختلف النوع CLICK_TO_CALL
عن النوع AD_CALL
من حيث أنّه لا يتتبّع المكالمات الهاتفية الفعلية. بدلاً من ذلك، لا يتتبّع CLICK_TO_CALL
سوى النقرات على
رقم هاتف من جهاز جوّال. ويكون هذا مفيدًا عندما يتعذر عليك استخدام
رقم توجيه المكالمات من Google لتتبع المكالمات الهاتفية.
AD_CALL
يظهر إجراء الإحالة الناجحة
AD_CALL
كإحالة ناجحة من نوع المكالمات من
الإعلانات في واجهة الويب لخدمة "إعلانات Google". بعد إنشاء إجراء الإحالة الناجحة على AD_CALL
، حدِّد اسم المورد في الحقل call_conversion_action
عند إنشاء CallAsset
. تتيح لك مواد عرض
المكالمات عرض
رقم هاتف في إعلاناتك مباشرةً.
ويتم تسجيل المكالمة كإحالة ناجحة إذا استمرت لمدة أطول من المدة المحددة. تبلغ المدة التلقائية 60 ثانية.
WEBSITE_CALL
يظهر إجراء الإحالة الناجحة
WEBSITE_CALL
على شكل إحالة ناجحة من نوع المكالمات من
موقع إلكتروني في واجهة
"إعلانات Google" على الويب.
على عكس
AD_CALL
،
تتطلّب أداة التتبُّع هذه إضافة event_snippet
وglobal_site_tag
إلى
موقعك الإلكتروني لاسترداد رقم توجيه المكالمات الديناميكي من Google لتتبُّع المكالمات
على الأرقام المدرَجة في موقعك الإلكتروني. وإضافةً إلى ذلك، عليك إعداد مادة عرض
مكالمة وربطها على
مستوى العميل أو الحملة أو المجموعة الإعلانية.
استيراد الإحالات الناجحة خارج إطار الإنترنت
يعرض الجدول التالي معلمات ConversionActionType
API المكافئة المطلوب استخدامها لكل مصدر في واجهة الويب في "إعلانات Google"، ورابطًا إلى المستندات لكل نوع إجراء إحالة ناجحة محدد:
نوع إجراء الإحالة الناجحة | مصدر "إعلانات Google" | دليل إعداد واجهة برمجة التطبيقات |
---|---|---|
UPLOAD_CLICKS |
تتبُّع الإحالات الناجحة من خلال النقرات والإحالات الناجحة المحسّنة للعملاء المحتملين | دليل النقرات المحمَّلة
دليل الإحالات الناجحة المحسَّنة للعملاء المحتملين |
UPLOAD_CALLS |
تتبع الإحالات الناجحة من المكالمات | دليل إعداد واجهة برمجة التطبيقات |
STORE_SALES |
تتبُّع الإحالات الناجحة للمبيعات في المتاجر | دليل إعداد واجهة برمجة التطبيقات |
الإحالات الناجحة المحسّنة للويب
تتيح لك الإحالات الناجحة المحسّنة للويب إرسال بيانات الإحالات الناجحة للطرف الأول لإجراءات إحالة ناجحة (WEBPAGE
) خلال 24 ساعة من حدث إحالة ناجحة بدلاً من الوقت نفسه. وهذا يتيح إمكانية العثور على بيانات الطرف الأول من مجموعة متنوعة من المصادر، مثل قاعدة بيانات العملاء أو نظام إدارة علاقات العملاء.
أنواع إجراءات الإحالات الناجحة الإضافية
توفّر واجهة Google Ads API أنواعًا إضافية من إجراءات الإحالات الناجحة في التقارير، ولكن قد تحدّ من إنشاء تلك الإجراءات أو تعديلها أو تحظرها.
إحالات SKAdNetwork الناجحة
إذا كنت تدير حملات تطبيقات iOS
ونفّذت
SKAdNetwork، يمكنك الوصول إلى
بياناتSKAdNetwork المقدَّمة إلى Google على مستوى Customer
وCampaign
باستخدام
المراجع التالية:
حقل التقرير | الوصف |
---|---|
metrics.sk_ad_network_installs |
عدد عمليات التثبيت التي أبلغت عنها Apple لا يمكن تقسيم هذا المقياس إلا حسب
أي مجموعة من شرائح segments.sk_ad_network_conversion_value
والشرائح ذات الصلة بالتاريخ.
|
metrics.sk_ad_network_total_conversions |
إجمالي عدد الإحالات الناجحة، بما في ذلك عمليات التثبيت وغيرها من أنواع الإحالات الناجحة التي تسجّلها Apple. لا يمكن تقسيم هذا المقياس إلا حسب الشرائح المرتبطة بالتاريخ والشرائح المرتبطة بـ SKAdNetwork. |
segments.sk_ad_network_ad_event_type |
نوع الحدث الذي وقع لإحالة ناجحة معيّنة. |
segments.sk_ad_network_attribution_credit |
كيفية احتساب تحديد المصدر لإحالة ناجحة معيّنة |
segments.sk_ad_network_fine_conversion_value |
قيمة الإحالة الناجحة التي أبلغت عنها Apple. لا يمكن تطبيق هذه الشريحة
على أي مقاييس غير يتم عرض القيمة |
segments.sk_ad_network_coarse_conversion_value |
القيمة التقريبية لإحالة ناجحة فردية. |
segments.sk_ad_network_postback_sequence_index |
موضع تسجيل الإحالات الناجحة بالتسلسل لإحالة ناجحة معيّنة. |
segments.sk_ad_network_source_app.sk_ad_network_source_app_id |
رقم تعريف التطبيق الذي ظهر فيه الإعلان الذي أدّى إلى تثبيت شبكة إعلانات iOS Store Kit. |
segments.sk_ad_network_source_domain |
الموقع الإلكتروني الذي ظهر فيه الإعلان الذي أدّى إلى تثبيت شبكة إعلانات iOS StoreKit. تعني القيمة الفارغة أنّ هذه الشريحة غير قابلة للتطبيق، مثل حملة لا تعمل على نظام التشغيل iOS، أو لم تكن متوفّرة في أي عمليات تسجيل إحالات ناجحة أرسلتها Apple. |
segments.sk_ad_network_source_type |
نوع المصدر الذي كان فيه الإعلان الذي أدّى إلى تثبيت شبكة إعلانات iOS Store Kit. وتعني القيمة الفارغة أنّ هذه الشريحة غير قابلة للتطبيق، على سبيل المثال، حملة لا تعمل على نظام التشغيل iOS، أو أنه لم يتم العثور على النطاق المصدر أو التطبيق المصدر في أي عمليات تسجيل إحالات ناجحة أرسلتها Apple. |
segments.sk_ad_network_user_type |
نوع المستخدِم الذي أنشأ إحالة ناجحة معيّنة. |
segments.sk_ad_network_redistributed_fine_conversion_value |
تتضمّن قيم الإحالات الناجحة في هذه الشريحة قيمًا فارغة تمت إعادة توزيعها على قيم الإحالات الناجحة. يمثّل هذا القسم مجموع قيم الإحالات الناجحة الدقيقة المرصودة التي تعرضها Apple والقيم الفارغة المستندة إلى نموذج من Google. |
يمكنك أيضًا حفظ عملية ربط قيمة الإحالة الناجحة على SKAdNetwork لعملاء محدّدين من خلال تطبيقات iOS من خلال CustomerSkAdNetworkConversionValueSchema
.
نموذج رمز Python
#!/usr/bin/env python # Copyright 2019 Google LLC # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # https://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. import argparse import sys from google.ads.googleads.client import GoogleAdsClient from google.ads.googleads.errors import GoogleAdsException def main(client, customer_id): """Adds a keyword plan, campaign, ad group, etc. to the customer account. Also handles errors from the API and prints them. Args: client: An initialized instance of GoogleAdsClient customer_id: A str of the customer_id to use in requests. """ res = update_skan_cv_schema( client, customer_id, "my_app_id", "account_link_id" ) print(res) def update_skan_cv_schema(client, customer_id, app_id, account_link_id): skan_service = client.get_service( "CustomerSkAdNetworkConversionValueSchemaService" ) req = client.get_type( "MutateCustomerSkAdNetworkConversionValueSchemaRequest" ) operation = client.get_type( "CustomerSkAdNetworkConversionValueSchemaOperation" ) schema_instance = client.get_type( "CustomerSkAdNetworkConversionValueSchema" ) new_schema = operation.update new_schema.resource_name = ( skan_service.customer_sk_ad_network_conversion_value_schema_path( "customer_id", "account_link_id" ) ) new_schema.schema.app_id = app_id new_schema.schema.measurement_window_hours = 48 skan_cv_mapping = ( schema_instance.SkAdNetworkConversionValueSchema.FineGrainedConversionValueMappings() ) skan_cv_mapping.fine_grained_conversion_value = 0 # 0 - 63 skan_cv_mapping.conversion_value_mapping.min_time_post_install_hours = 0 skan_cv_mapping.conversion_value_mapping.max_time_post_install_hours = 48 skan_cv_event = schema_instance.SkAdNetworkConversionValueSchema.Event() skan_cv_event.mapped_event_name = "TEST" skan_cv_event.event_revenue_value = 10 skan_cv_mapping.conversion_value_mapping.mapped_events.append(skan_cv_event) new_schema.schema.fine_grained_conversion_value_mappings.append( skan_cv_mapping ) req.operation = operation req.customer_id = customer_id res = skan_service.mutate_customer_sk_ad_network_conversion_value_schema( req ) return res if __name__ == "__main__": # GoogleAdsClient will read the google-ads.yaml configuration file in the # home directory if none is specified. googleads_client = GoogleAdsClient.load_from_storage( version="v17" ) parser = argparse.ArgumentParser( description="Creates a keyword plan for specified customer." ) # The following argument(s) should be provided to run the example. parser.add_argument( "-c", "--customer_id", type=str, required=True, help="The Google Ads customer ID.", ) args = parser.parse_args() try: main(googleads_client, args.customer_id) except GoogleAdsException as ex: print( f'Request with ID "{ex.request_id}" failed with status ' f'"{ex.error.code().name}" and includes the following errors:' ) for error in ex.failure.errors: print(f'\tError with message "{error.message}".') if error.location: for field_path_element in error.location.field_path_elements: print(f"\t\tOn field: {field_path_element.field_name}") sys.exit(1)
إحصاءات Google
تتضمّن الإحالات الناجحة من موقع مرتبط على "إحصاءات Google" إحدى قيم
type
التالية:
الإحالة الناجحة للموقع على "إحصاءات Google 4":
GOOGLE_ANALYTICS_4_CUSTOM
GOOGLE_ANALYTICS_4_PURCHASE
يمكنك أيضًا استرداد رقم تعريف موقع "إحصاءات Google 4" واسم الموقع واسم الحدث من الحقل
google_analytics_4_settings
.الإحالة الناجحة للموقع على Universal Analytics:
UNIVERSAL_ANALYTICS_GOAL
UNIVERSAL_ANALYTICS_TRANSACTION
يمكنك إجراء التغييرات التالية على إحالة ناجحة للموقع على "إحصاءات Google 4":
- يمكنك استيراد الإحالة الناجحة من موقعك على "إحصاءات Google 4" إلى حسابك على "إعلانات Google" من خلال
تعديل حقل
status
منHIDDEN
إلىENABLED
. - عدِّل حقلَي
primary_for_goal
وcategory
لتوضيح كيفية تأثيره في عروض الأسعار والتقارير في "إعلانات Google". - يجب تعديل
name
أوvalue_settings
. - أزِل الإحالة الناجحة من حسابك على "إعلانات Google" باستخدام عملية
remove
.
تؤدّي أي محاولة لتعديل سمات أخرى لإحالة ناجحة تمّ استيرادها من "إحصاءات Google 4" أو أي
سمات لإحالة ناجحة تمّ استيرادها في Universal Analytics إلى حدوث خطأ
MUTATE_NOT_ALLOWED
. لا يمكنك إجراء هذه التغييرات إلا باستخدام واجهة مستخدم "إعلانات Google".
Firebase وإحصاءات التطبيقات التابعة لجهات خارجية
لاستيراد
إحصاءات التطبيقات التابعة لجهات خارجية
أو الإحالات الناجحة من Firebase،
عليك تغيير status
في
ConversionAction
من HIDDEN
إلى ENABLED
باستخدام طريقة mutate
ConversionActionService
. لا يمكن تعديل
app_id
لإجراءات الإحالات الناجحة هذه.
FIREBASE_ANDROID_FIRST_OPEN
FIREBASE_ANDROID_IN_APP_PURCHASE
FIREBASE_ANDROID_CUSTOM
FIREBASE_IOS_FIRST_OPEN
FIREBASE_IOS_IN_APP_PURCHASE
FIREBASE_IOS_CUSTOM
THIRD_PARTY_APP_ANALYTICS_ANDROID_FIRST_OPEN
THIRD_PARTY_APP_ANALYTICS_ANDROID_IN_APP_PURCHASE
THIRD_PARTY_APP_ANALYTICS_ANDROID_CUSTOM
THIRD_PARTY_APP_ANALYTICS_IOS_FIRST_OPEN
THIRD_PARTY_APP_ANALYTICS_IOS_IN_APP_PURCHASE
THIRD_PARTY_APP_ANALYTICS_IOS_CUSTOM
مبيعات المتجر
على الرغم من أنّه لا يمكنك إنشاء إجراءات إحالات ناجحة STORE_SALES
أو STORE_SALES_DIRECT_UPLOAD
باستخدام Google Ads API، تتيح واجهة برمجة التطبيقات تحميل معاملات المبيعات في المتاجر.
STORE_SALES
STORE_SALES_DIRECT_UPLOAD
خيارات متنوعة
إنّ أنواع إجراءات الإحالات الناجحة التالية هي للقراءة فقط في Google Ads API، ويتم توفيرها لأغراض إعداد التقارير.
ANDROID_APP_PRE_REGISTRATION
ANDROID_INSTALLS_ALL_OTHER_APPS
FLOODLIGHT_ACTION
FLOODLIGHT_TRANSACTION
GOOGLE_HOSTED
LEAD_FORM_SUBMIT
SALESFORCE
SEARCH_ADS_360
SMART_CAMPAIGN_AD_CLICKS_TO_CALL
SMART_CAMPAIGN_MAP_CLICKS_TO_CALL
SMART_CAMPAIGN_MAP_DIRECTIONS
SMART_CAMPAIGN_TRACKED_CALLS
STORE_VISITS
WEBPAGE_CODELESS
غير معروف
إذا كان حسابك على "إعلانات Google" يتضمّن أنواعًا أخرى من إجراءات الإحالات الناجحة، قد يتبيّن لك أنّ طلبات البحث والتقارير تعرِض إجراءات إحالات ناجحة حيث تكون قيمة
ConversionAction.type
هي UNKNOWN
.
لا تتيح واجهة برمجة التطبيقات إدارة إجراءات الإحالات الناجحة هذه، ولكنها تعرِضها في
التقارير لتقديم نتائج كاملة لمقاييس الإحالات الناجحة الرئيسية مثل
metrics.conversions
وmetrics.conversions_value
.
مثال على الرمز البرمجي
يوجِّهك مثال الرمز التالي خلال عملية إنشاء إجراء إحالة ناجحة جديد. وعلى وجه التحديد، يتم إنشاء إجراء إحالة ناجحة مع ضبط
type
على
UPLOAD_CLICKS
.
هذا هو مسار واجهة مستخدم "إعلانات Google" نفسه المستخدَم لإنشاء إجراء إحالة ناجحة جديد باستخدام
الاستيراد > الاستيراد اليدوي باستخدام واجهة برمجة التطبيقات أو عمليات التحميل > تتبّع الإحالات الناجحة من
النقرات. وهي تضبط أيضًا السمة 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.V17.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::V17::Resources::ConversionAction->new({ name => $conversion_action_name, category => DEFAULT, type => WEBPAGE, status => ENABLED, viewThroughLookbackWindowDays => 15, valueSettings => Google::Ads::GoogleAds::V17::Resources::ValueSettings->new({ defaultValue => 23.41, alwaysUseDefaultValue => "true" })}); # Create a conversion action operation. my $conversion_action_operation = Google::Ads::GoogleAds::V17::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" و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
يجب أن يتم ضبط
always_use_default_value
علىtrue
فيvalue_settings
لإجراء الإحالة الناجحةWEBSITE_CALL
أوAD_CALL
. يؤدي تحديد قيمةfalse
عند إنشاء هذه القيمة أو تعديلها إلى ظهور خطأINVALID_VALUE
.view_through_lookback_window_days
يؤدي ضبط هذه السمة على قيمة خارج النطاق المسموح به إلى حدوث خطأ
RangeError.TOO_LOW
أوRangeError.TOO_HIGH
. بالنسبة إلى معظم إجراءات الإحالة الناجحة، النطاق المسموح به هو[1,30]
.لا يمكن ضبط هذه السمة على
AD_CALL
أوWEBSITE_CALL
إجراء إحالة ناجحة. يؤدي تحديد قيمة إلى خطأVALUE_MUST_BE_UNSET
.