יצירת פעולות המרה

במדריך הזה אנחנו מפרטים את הסוגים השונים של פעולות ההמרה שאפשר להגדיר ליצור באמצעות 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 שעות אחרי את האירוע ההמרה, במקום את אותו אירוע. כך אפשר לאתר נתונים מאינטראקציה ישירה (First-Party) ממגוון מקורות, כמו מסד נתונים של לקוחות או ניהול קשרי לקוחות (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. לא ניתן להחיל את הפלח הזה לכל מדד שאינו metrics.sk_ad_network_installs, metrics.sk_ad_network_total_conversions, וגם ניתן לשלב רק עם פלחים הקשורים לתאריכים.

הערך 0 מוחזר אם Apple מדווחת על ערך של 0 וללא ערך אחר. כדאי לבדוק את את הנוכחות באינטרנט כדי להבחין בין שני המקרים.

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, או שהוא לא נכלל בדיווחים חוזרים על המרות (PostBack) שנשלחו על ידי 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.
segments.sk_ad_network_version גרסת iOS Store Kit Ad Network API שבה נעשה שימוש.

אפשר גם לשמור מיפוי של ערכי המרות ב-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 או כלשהו של המרה מיובאת מ-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.

הגדרות ברירת המחדל הבאות חלות:

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.