במדריך הזה מופיעה רשימה של הסוגים השונים של פעולות ההמרה שאפשר ליצור באמצעות Google Ads API, מידע על אופן המיפוי של פעולות ההמרה לממשק האינטרנט של Google Ads, וקוד לדוגמה שמראה איך ליצור פעולות המרה חדשות.
כדי למדוד המרות, צריך להגדיר ConversionAction
עבור type
של פעולת ההמרה שרוצים לעקוב אחריה. לדוגמה, קנייה באינטרנט ושיחת טלפון
מחייבות פעולות המרה שונות.
הדרך הטובה ביותר להגדיר פעולות המרה חדשות ב-API היא באמצעות הדוגמה הבאה להוספת קוד פעולת המרה. הדוגמה הזו מטפלת במשימות האימות ברקע ומנחה אתכם איך ליצור ConversionAction
.
כדי לעקוב אחרי פעולות ההמרה האלה, צריך לבצע גם שלבים נוספים. לדוגמה, כדי לעקוב אחרי המרות באתר, צריך להוסיף לדף ההמרות באתר קטע קוד שנקרא תג. דרישות נוספות לגבי פעולות המרה מפורטות במאמר במרכז העזרה.
המרות באתר
המרה באתר מאפשרת לכם לעקוב אחרי פעולות באתר, כמו מכירות אונליין, קליקים על קישורים, צפיות בדפים והרשמות.
כדי לעקוב אחרי המרות באתר, צריך ליצור ConversionAction
שבו ConversionActionType
מוגדר ל-WEBPAGE
ולהוסיף קטע קוד שנקרא תג בדף ההמרות באתר.
ConversionAction
מכיל כמה סוגים של המרות באתר, שמבחינים ב-API באמצעות השדה type
בכל TagSnippet
שדה tag_snippets של ConversionAction
.
התג TagSnippet
מספק את קוד המעקב שצריך לכלול באתר כדי לעקוב אחרי פעולות ההמרה.
כדי לבצע המרות מסוג אתר וקליק על מספר טלפון, צריך למקם את הפרמטר event_snippet
בדפי אינטרנט שמציינים פעולת המרה, כמו דף אישור תשלום או דף שליחת טופס להשארת פרטים, וגם global_site_tag
, שחייב להיות מותקן בכל דף באתר. אפשר לאחזר את שני המאפיינים האלה באמצעות ConversionActionService
. במרכז העזרה יש מידע נוסף על תיוג הדפים.
בטבלה הבאה מפורטים הפרמטרים המקבילים של API שבהם צריך להשתמש בכל מקור בממשק האינטרנט של Google Ads:
סוג קוד מעקב | מקור ב-Google Ads |
---|---|
WEBPAGE |
אתר, אתר (Google Analytics (GA4)) |
WEBPAGE_ONCLICK |
אתר, אתר (Google Analytics (GA4)) |
CLICK_TO_CALL |
קליקים על מספר טלפון |
--- |
אתר (Google Analytics (UA)) |
המרות באפליקציה
המרה באפליקציה מאפשרת לכם לעקוב אחרי התקנות של אפליקציה לנייד או רכישות מתוך האפליקציה מחנות Google Play.
בטבלה הבאה מוצגים הפרמטרים המקבילים של ConversionActionType
ב-API שבהם צריך להשתמש בכל מקור בממשק האינטרנט של Google Ads:
סוג פעולת ההמרה | מקור ב-Google Ads |
---|---|
GOOGLE_PLAY_DOWNLOAD |
Google Play > התקנות |
GOOGLE_PLAY_IN_APP_PURCHASE |
Google Play > רכישות מתוך האפליקציה |
אם אתם רוצים לעקוב אחרי פעולות אחרות באפליקציה לנייד באמצעות נכסי Google Analytics 4 או ניתוחים של נתוני אפליקציות של צד שלישי. כדאי לעיין במאמר סוגים נוספים של פעולות המרה.
המרות מסוג שיחת טלפון
מעקב המרות מסוג שיחת טלפון מאפשר לכם לעקוב אחרי שיחות ממודעות, שיחות למספר שמופיע באתר וקליקים על מספרים באתרים לנייד.
בטבלה הבאה מוצגים הפרמטרים המקבילים של ConversionActionType
ב-API שבהם צריך להשתמש בכל מקור בממשק האינטרנט של Google Ads:
סוג פעולת ההמרה | מקור ב-Google Ads |
---|---|
AD_CALL |
שיחות ממודעות עם תוספי שיחה או ממודעות לשיחות בלבד |
WEBSITE_CALL |
שיחות למספר טלפון שמוצג באתר |
CLICK_TO_CALL |
קליקים על מספר באתר שלך לנייד |
הסוג CLICK_TO_CALL
שונה מסוג AD_CALL
בכך שהוא לא עוקב אחרי שיחות טלפון בפועל. במקום זאת, CLICK_TO_CALL
עוקב רק אחרי קליקים על מספר טלפון ממכשיר נייד. האפשרות הזו שימושית במקרים שבהם אי אפשר להשתמש במספר Google לניתוח נתוני שיחות והודעות כדי לעקוב אחרי שיחות טלפון.
AD_CALL
פעולת המרה AD_CALL
מופיעה כהמרה מסוג שיחות ממודעות בממשק האינטרנט של Google Ads. אחרי שיוצרים את פעולת ההמרה AD_CALL
, צריך לציין את שם המשאב שלה בשדה call_conversion_action
כשיוצרים את CallAsset
. נכסי התקשרות מאפשרים להציג מספר טלפון ישירות במודעות.
שיחה מדווחת כהמרה אם היא נמשכת יותר מפרק זמן מסוים. ערך ברירת המחדל הוא 60 שניות.
WEBSITE_CALL
פעולת המרה WEBSITE_CALL
מופיעה כהמרה מסוג שיחות מאתר בממשק האינטרנט של Google Ads.
בניגוד ל-AD_CALL
, צריך להוסיף לאתר את event_snippet
ואת global_site_tag
כדי לאחזר את מספר Google לניתוח נתוני שיחות והודעות למעקב אחרי שיחות במספרים שמופיעים באתר. בנוסף, צריך להגדיר נכס התקשרות ולקשר אותו ברמת הלקוח, הקמפיין או קבוצת המודעות.
ייבוא המרות אופליין
בטבלה הבאה מוצגים הפרמטרים המקבילים של
ConversionActionType
API שבהם צריך להשתמש לכל מקור בממשק האינטרנט של Google Ads,
וקישור למסמכי התיעוד של כל סוג ספציפי של פעולת המרה:
סוג פעולת ההמרה | מקור ב-Google Ads | מדריך להגדרת API |
---|---|---|
UPLOAD_CLICKS |
מעקב אחרי המרות מקליקים והמרות משופרות ללידים | מדריך בנושא קליקים על העלאה
המדריך לשימוש בהמרות משופרות לצורך שיוך ללידים |
UPLOAD_CALLS |
מעקב אחר המרות משיחות | מדריך להגדרת API |
STORE_SALES |
מעקב אחר המרות ומכירות בחנות | מדריך להגדרת API |
תיעוד המרות משופר באתרים
תיעוד המרות משופר באתרים מאפשר לשלוח נתוני המרות מאינטראקציה ישירה (First-Party) של WEBPAGE
פעולות המרה תוך 24 שעות מאירוע המרה, במקום לכל הפעילות בו-זמנית. כך אפשר לאתר נתונים מאינטראקציה ישירה ממגוון מקורות, כמו מסד נתונים של לקוחות או מערכת לניהול קשרי לקוחות (CRM).
סוגים נוספים של פעולות המרה
ב-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 |
המיקום של הדיווח החוזר על המרה (PostBack) ברצף של המרה מסוימת. |
segments.sk_ad_network_source_app.sk_ad_network_source_app_id |
מזהה האפליקציה שבו הוצגה המודעה שהובילה להתקנה של iOS Store Kit Ad Network. |
segments.sk_ad_network_source_domain |
האתר שבו הוצגה המודעה שהובילה להתקנה של iOS Store Kit Ad Network. משמעות הערך null היא שהפלח הזה לא רלוונטי – לדוגמה, קמפיין שאינו ל-iOS – או שהוא לא היה קיים בדיווחים חוזרים על המרות שנשלחו על ידי Apple. |
segments.sk_ad_network_source_type |
סוג המקור שבו הוצגה המודעה שהובילה להתקנה של iOS Store Kit Ad Network. משמעות הערך null היא שהפלח הזה לא רלוונטי – לדוגמה, קמפיין שאינו ל-iOS – או שהדומיין של המקור ואפליקציית המקור לא היו קיימים בדיווחים חוזרים על המרות (PostBack) שנשלחו על ידי Apple. |
segments.sk_ad_network_user_type |
סוג המשתמש שיצר המרה מסוימת. |
segments.sk_ad_network_redistributed_fine_conversion_value |
ערכי ההמרות בפלח הזה כוללים ערכי null שהופצו מחדש לערכי המרות. הפלח הזה מייצג את הסכום של ערכי ההמרות המפורטים שנמצאו על ידי Apple, וערכי null לפי מודל מ-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 Analytics
להמרות מנכס Google Analytics מקושר יש אחד מהערכים הבאים של type
:
המרה בנכס GA4:
GOOGLE_ANALYTICS_4_CUSTOM
GOOGLE_ANALYTICS_4_PURCHASE
אפשר גם לאחזר את מזהה נכס GA4, שם הנכס ושם האירוע מהשדה
google_analytics_4_settings
.המרה של נכס Universal Analytics:
UNIVERSAL_ANALYTICS_GOAL
UNIVERSAL_ANALYTICS_TRANSACTION
אפשר לבצע את השינויים הבאים בהמרה של נכס GA4:
- מייבאים את ההמרה מנכס GA4 לחשבון Google Ads על ידי שינוי השדה
status
שלו מ-HIDDEN
ל-ENABLED
. - משנים את השדות
primary_for_goal
ו-category
כדי להסביר איך הוא אמור להשפיע על הבידינג והדוחות ב-Google Ads. - מעדכנים את
name
או אתvalue_settings
. - מסירים את ההמרה מחשבון Google Ads באמצעות פעולת
remove
.
כל ניסיון לשנות מאפיינים אחרים של המרה מיובאת מ-GA4 או כל מאפיין של המרה מיובאת מ-Universal Analytics, יוביל לשגיאה MUTATE_NOT_ALLOWED
. אפשר לבצע את השינויים האלה רק באמצעות ממשק המשתמש של Google Ads.
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, אבל ה-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 Ads שלכם יש סוגים אחרים של פעולות המרה, יכול להיות שתגלו ששאילתות ודיווחים מחזירות פעולות המרה שבהן הערך ConversionAction.type
הוא UNKNOWN
.
ה-API לא תומך בניהול פעולות ההמרה האלה, אבל הוא מחזיר אותן בדוחות כדי לספק תוצאות מלאות למדדי המרות עיקריים כמו metrics.conversions
ו-metrics.conversions_value
.
קוד לדוגמה
הקוד שבדוגמה הבאה ינחה אתכם בתהליך היצירה של פעולת המרה חדשה. באופן ספציפי, היא יוצרת פעולת המרה עם type
שמוגדר ל-UPLOAD_CLICKS
.
זו אותה תהליך בממשק המשתמש של Google Ads כמו יצירה של פעולת המרה חדשה באמצעות ייבוא > ייבוא ידני באמצעות API או העלאות > מעקב אחר המרות מקליקים. הוא גם מגדיר את category
כ-DEFAULT
.
הגדרות ברירת המחדל הבאות חלות:
השדה
primary_for_goal
מוגדר באופן אוטומטי ב-Google Ads API, אבל אפשר להגדיר את השדה הזה באופן מפורש כדי לקבוע איך פעולת המרה משפיעה על הדיווח ועל הבידינג בחשבון בשילוב עם יעדי ההמרה.ב-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 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 תומך רק ב-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
.