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

במדריך הזה מופיעה רשימה של הסוגים השונים של פעולות ההמרה שאפשר ליצור באמצעות Google Ads API, מידע על האופן שבו פעולות ההמרה האלה ממופות לממשק האינטרנט של Google Ads, ודוגמה לקוד מפורטת שמדגימה איך ליצור פעולות המרה חדשות.

כדי למדוד המרות, צריך להגדיר ConversionAction ל-type של פעולת ההמרה שאחריה רוצים לעקוב. לדוגמה, רכישה באינטרנט ושיחת טלפון מחייבות פעולות המרה שונות.

הדרך הטובה ביותר להגדיר פעולות המרה חדשות ב-API היא להשתמש בדוגמה להוספת קוד של פעולת המרה שמופיעה בהמשך. הדוגמה מטפלת בכל משימות האימות ברקע, ומסבירה איך ליצור ConversionAction.

רוב פעולות ההמרה מחייבות גם שלבים נוספים כדי לעקוב אחריהן. לדוגמה, כדי לעקוב אחר המרות באתר, צריך להוסיף לדף ההמרות באתר קטע קוד שנקרא תג. למידע על דרישות אחרות לגבי פעולות המרה, תוכלו לקרוא את המאמר הזה במרכז העזרה.

המרות באתר

המרה באתר מאפשרת לך לעקוב אחר פעולות באתר כמו מכירות באינטרנט, קליקים על קישורים, צפיות בדפים והרשמות.

כדי לעקוב אחרי המרות באתר, צריך ליצור ConversionAction עם הערך WEBPAGE ב-ConversionActionType, ולהוסיף לדף ההמרות באתר קטע קוד שנקרא תג.

ConversionAction כולל כמה סוגים של המרות באתר, שההבדל בין ה-API לבין השדה type הוא השדה 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_conversions מספר ההמרות שדווחו על ידי Apple. ניתן לפלח את המדד הזה רק לפי שילוב של segments.sk_ad_network_conversion_value ופלחים הקשורים לתאריכים.
segments.sk_ad_network_conversion_value

הערך של המרה שמדווחת על ידי Apple. לא ניתן להחיל את הפלח הזה על אף מדד שאינו metrics.sk_ad_network_conversions, ואפשר לשלב אותו רק עם פלחים הקשורים לתאריכים.

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

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

    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, הוא כן תומך בהעלאת עסקאות של מכירות בחנות הפיזית.

  • 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.V16.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::V16::Resources::ConversionAction->new({
      name                          => $conversion_action_name,
      category                      => DEFAULT,
      type                          => WEBPAGE,
      status                        => ENABLED,
      viewThroughLookbackWindowDays => 15,
      valueSettings                 =>
        Google::Ads::GoogleAds::V16::Resources::ValueSettings->new({
          defaultValue          => 23.41,
          alwaysUseDefaultValue => "true"
        })});

  # Create a conversion action operation.
  my $conversion_action_operation =
    Google::Ads::GoogleAds::V16::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;
}
      

דוגמה זו נמצאת גם בתיקייה 'רימרקטינג' בספריית הלקוח ובאוסף הדוגמאות של הקוד: Add Conversion Action code example (הוספת דוגמה לקוד של פעולת המרה).

פורמטים מאושרים

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.