Conversion-Aktionen erstellen

Dieser Leitfaden enthält eine Liste der verschiedenen Arten von Conversion-Aktionen, die Sie mit der Google Ads API erstellen können, Informationen dazu, wie diese der Google Ads-Weboberfläche zugeordnet werden. Außerdem finden Sie ein detailliertes Codebeispiel zum Erstellen neuer Conversion-Aktionen.

Wenn Sie Conversions erfassen möchten, richten Sie eine ConversionAction für die type der Conversion-Aktion ein, die Sie erfassen möchten. Für einen Onlinekauf und einen Telefonanruf sind beispielsweise unterschiedliche Conversion-Aktionen erforderlich.

Wenn Sie neue Conversion-Aktionen in der API einrichten möchten, verwenden Sie am besten das Codebeispiel zum Hinzufügen einer Conversion-Aktion unten. Das Beispiel verarbeitet alle Hintergrundauthentifizierungsaufgaben für Sie und führt Sie durch das Erstellen eines ConversionAction.

Bei den meisten Conversion-Aktionen sind zusätzliche Schritte erforderlich, um sie zu erfassen. Wenn Sie beispielsweise Conversions auf Ihrer Website erfassen möchten, müssen Sie der Conversion-Seite auf Ihrer Website ein Code-Snippet, ein sogenanntes Tag, hinzufügen. Weitere Anforderungen an Conversion-Aktionen finden Sie in diesem Hilfeartikel.

Website-Conversions

Mit einer Website-Conversion können Sie Websiteaktionen wie Onlineverkäufe, Linkklicks, Seitenaufrufe und Anmeldungen erfassen.

Wenn Sie Conversions auf Ihrer Website erfassen möchten, müssen Sie eine ConversionAction erstellen, in der ConversionActionType auf WEBPAGE festgelegt ist. Außerdem müssen Sie der Conversion-Seite Ihrer Website ein als Tag bezeichnetes Code-Snippet hinzufügen.

Die ConversionAction umfasst mehrere Arten von Website-Conversions, die sich innerhalb der API durch das Feld type in jedem TagSnippet unterscheiden, der im Feld tag_snippets einer ConversionAction aufgeführt ist.

Ein TagSnippet enthält den Tracking-Code, der in Ihre Website eingefügt werden muss, damit Conversion-Aktionen erfasst werden können. Für Conversions vom Typ Website und Klick auf eine Telefonnummer ist das event_snippet erforderlich. Es muss auf Webseiten platziert werden, auf denen eine Conversion-Aktion angegeben ist, z. B. eine Zahlungsbestätigung oder eine Seite zum Senden eines Lead-Formulars. global_site_tag muss auf jeder Seite der Website installiert sein. Sie können beide Attribute mit ConversionActionService abrufen. Weitere Informationen zur Tag-Kennzeichnung Ihrer Seiten finden Sie in unserer Hilfe.

In der folgenden Tabelle sehen Sie die entsprechenden API-Parameter, die für die jeweilige Quelle in der Google Ads-Weboberfläche verwendet werden:

Tracking-Code-Typ Google Ads-Quelle
WEBPAGE Website, Website (Google Analytics (GA4))
WEBPAGE_ONCLICK Website, Website (Google Analytics (GA4))
CLICK_TO_CALL Anruf
--- Website (Google Analytics (UA))

App-Conversions

Mit einer App-Conversion können Sie Installationen einer mobilen App oder In-App-Käufe im Google Play Store erfassen.

In der folgenden Tabelle sehen Sie die entsprechenden ConversionActionType-API-Parameter, die für die jeweilige Quelle in der Google Ads-Weboberfläche verwendet werden:

Typ der Conversion-Aktion Google Ads-Quelle
GOOGLE_PLAY_DOWNLOAD Google Play > Installationen
GOOGLE_PLAY_IN_APP_PURCHASE Google Play > In-App-Käufe

Wenn Sie andere Aktionen in mobilen Apps mit Google Analytics 4-Properties oder App-Analysen von Drittanbietern erfassen möchten. Weitere Informationen

Anruf-Conversions

Mit Anruf-Conversion-Tracking können Sie Anrufe über Anzeigen, Anrufe bei einer Telefonnummer auf Ihrer Website und Klicks auf Telefonnummern auf mobilen Websites erfassen.

In der folgenden Tabelle sehen Sie die entsprechenden ConversionActionType-API-Parameter, die für die jeweilige Quelle in der Google Ads-Weboberfläche verwendet werden:

Typ der Conversion-Aktion Google Ads-Quelle
AD_CALL Anrufe über Nur-Anrufanzeigen oder Anzeigen mit Anruferweiterungen
WEBSITE_CALL Anrufe bei einer Telefonnummer auf Ihrer Website
CLICK_TO_CALL Klicks auf eine Telefonnummer auf Ihrer mobilen Website

Der Typ CLICK_TO_CALL unterscheidet sich vom Typ AD_CALL insofern, als er keine tatsächlichen Anrufe erfasst. Stattdessen erfasst CLICK_TO_CALL nur Klicks auf eine Telefonnummer auf einem Mobilgerät. Dies ist nützlich, wenn Sie keine Google-Weiterleitungsnummer zum Erfassen von Anrufen verwenden können.

AD_CALL

Auf der Google Ads-Weboberfläche wird die Conversion-Aktion AD_CALL als Conversion-Aktion Anrufe über Anzeigen angezeigt. Nachdem Sie die Conversion-Aktion AD_CALL erstellt haben, geben Sie beim Erstellen einer CallAsset den Ressourcennamen im Feld call_conversion_action an. Mit Anruf-Assets können Sie eine Telefonnummer in Ihre Anzeigen einbinden.

Ein Anruf wird als Conversion erfasst, wenn er eine festgelegte Mindestdauer übersteigt. Diese liegt standardmäßig bei 60 Sekunden.

WEBSITE_CALL

Eine Conversion-Aktion vom Typ WEBSITE_CALL wird in der Google Ads-Weboberfläche als Conversion vom Typ Anrufe von einer Website angezeigt.

Im Gegensatz zu AD_CALL müssen für diesen Tracker event_snippet und global_site_tag Ihrer Website hinzugefügt werden, damit die dynamische Google-Weiterleitungsnummer zum Anruf-Tracking für Telefonnummern auf Ihrer Website abgerufen wird. Darüber hinaus müssen Sie ein Anruf-Asset einrichten und es auf Kunden-, Kampagnen- oder Anzeigengruppenebene verknüpfen.

Offline-Conversions importieren

In der folgenden Tabelle sehen Sie die entsprechenden ConversionActionType-API-Parameter, die für jede Quelle in der Google Ads-Weboberfläche verwendet werden, sowie einen Link zur Dokumentation für jeden einzelnen Conversion-Aktionstyp:

Typ der Conversion-Aktion Google Ads-Quelle API-Einrichtungshandbuch
UPLOAD_CLICKS Klick-Conversions und erweiterte Conversions für Leads erfassen Leitfaden zu Klicks hochladen
Leitfaden zu erweiterten Conversions für Leads
UPLOAD_CALLS Anruf-Conversions erfassen API-Einrichtungsleitfaden
STORE_SALES Conversions vom Typ „Ladenverkäufe“ erfassen API-Einrichtungsleitfaden

Erweiterte Conversions für das Web

Mit erweiterten Conversions für das Web können Sie eigene Conversion-Daten für WEBPAGE Conversion-Aktionen innerhalb von 24 Stunden nach einem Conversion-Ereignis senden. Dadurch ist es möglich, selbst erhobene Daten aus einer Vielzahl von Quellen wie einer Kundendatenbank oder einem CRM-System zu finden.

Zusätzliche Typen von Conversion-Aktionen

Über die Google Ads API sind in Berichten zusätzliche Typen von Conversion-Aktionen verfügbar. Die Erstellung oder Änderung dieser Aktionen kann jedoch eingeschränkt oder verboten werden.

SKAdNetwork-Conversions

Wenn Sie iOS-App-Kampagnen ausführen und SKAdNetwork implementiert haben, können Sie über die folgenden Ressourcen auf SKAdNetwork-Daten zugreifen, die Google auf Customer- und Campaign-Ebene bereitgestellt werden:

Berichtsfeld Beschreibung
metrics.sk_ad_network_installs Die Anzahl der von Apple gemeldeten Installationen. Dieser Messwert kann nur nach einer beliebigen Kombination aus segments.sk_ad_network_conversion_value und datumsbezogenen Segmenten segmentiert werden.
metrics.sk_ad_network_total_conversions Die Gesamtzahl der Conversions, einschließlich Installationen und anderer Conversion-Typen, die von Apple gemeldet wurden. Dieser Messwert kann nur nach SKAdNetwork- und datumsbezogenen Segmenten segmentiert werden.
segments.sk_ad_network_ad_event_type Die Art des Ereignisses, das für eine bestimmte Conversion aufgetreten ist.
segments.sk_ad_network_attribution_credit Hier wird beschrieben, wie die Attribution einer bestimmten Conversion zugeordnet wird.
segments.sk_ad_network_fine_conversion_value

Wert einer Conversion, die von Apple gemeldet wurde. Dieses Segment kann nicht auf andere Messwerte als metrics.sk_ad_network_installs und metrics.sk_ad_network_total_conversions angewendet werden und nur mit datumsbezogenen Segmenten kombiniert werden.

Der Wert 0 wird zurückgegeben, wenn Apple einen Wert von 0 meldet, ansonsten wird kein Wert ausgegeben. Prüfe die Feldpräsenz, um zwischen den beiden Fällen zu unterscheiden.

segments.sk_ad_network_coarse_conversion_value Der grobe Wert für eine einzelne Conversion.
segments.sk_ad_network_postback_sequence_index Die Position des Postbacks der Reihe nach bei einer bestimmten Conversion.
segments.sk_ad_network_source_app.sk_ad_network_source_app_id Die ID der App, in der die Anzeige ausgeliefert wurde, die zur Installation des iOS Store Kit-Werbenetzwerks geführt hat.
segments.sk_ad_network_source_domain Die Website, auf der die Anzeige ausgeliefert wurde, die zur Installation des iOS Store Kit Ad Network ausgeliefert wurde. Ein Nullwert bedeutet, dass dieses Segment nicht anwendbar ist (z. B. Nicht-iOS-Kampagne) oder in Postbacks, die von Apple gesendet wurden, nicht vorhanden war.
segments.sk_ad_network_source_type Der Quelltyp, in dem die Anzeige zu sehen war, die die Installation des iOS Store Kit Ad Network ausgelöst hat. Ein Nullwert bedeutet, dass dieses Segment nicht anwendbar ist (z. B. eine Nicht-iOS-Kampagne) oder dass in Postbacks, die von Apple gesendet wurden, weder die Quelldomain noch die Quell-App vorhanden waren.
segments.sk_ad_network_user_type Der Typ des Nutzers, der eine bestimmte Conversion generiert hat.
segments.sk_ad_network_redistributed_fine_conversion_value Die Conversion-Werte in diesem Segment enthalten Nullwerte, die in Conversion-Werte umverteilt wurden. Dieses Segment stellt die Summe der beobachteten feinen Conversion-Werte, die von Apple zurückgegeben wurden, und der geschätzten Nullwerte von Google dar.

Über CustomerSkAdNetworkConversionValueSchema können Sie auch eine SKAdNetwork-Conversion-Wert-Zuordnung für bestimmte verknüpfte Kunden mit iOS-Apps speichern.

Python-Beispielcode

#!/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

Conversions aus einer verknüpften Google Analytics-Property haben einen der folgenden type-Werte:

  • GA4-Property-Conversion:

    • GOOGLE_ANALYTICS_4_CUSTOM
    • GOOGLE_ANALYTICS_4_PURCHASE

    Sie können die GA4-Property-ID, den Property-Namen und den Ereignisnamen auch aus dem Feld google_analytics_4_settings abrufen.

  • Universal Analytics-Property-Conversion:

    • UNIVERSAL_ANALYTICS_GOAL
    • UNIVERSAL_ANALYTICS_TRANSACTION

Sie können folgende Änderungen an einer GA4-Property-Conversion vornehmen:

  • Importieren Sie die Conversion aus der GA4-Property in Ihr Google Ads-Konto. Ändern Sie dazu das Feld status von HIDDEN in ENABLED.
  • Ändern Sie die Felder primary_for_goal und category, um anzugeben, wie sich dies auf Google Ads-Gebote und -Berichte auswirken soll.
  • Aktualisieren Sie die name oder value_settings.
  • Entfernen Sie die Conversion mithilfe eines remove-Vorgangs aus Ihrem Google Ads-Konto.

Beim Versuch, andere Attribute einer importierten GA4-Conversion oder alle Attribute einer importierten Universal Analytics-Conversion zu ändern, wird der Fehler MUTATE_NOT_ALLOWED zurückgegeben. Diese Änderungen können Sie nur über die Google Ads-Benutzeroberfläche vornehmen.

Firebase und App-Analysen von Drittanbietern

Wenn Sie App-Analysen von Drittanbietern oder Firebase-Conversions importieren möchten, ändern Sie den status der ConversionAction von HIDDEN in ENABLED. Verwenden Sie dazu die Methode mutate von ConversionActionService. Das Aktualisieren von app_id wird für diese Conversion-Aktionen nicht unterstützt.

  • 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

Ladenverkäufe

Auch wenn Sie mit der Google Ads API keine STORE_SALES- oder STORE_SALES_DIRECT_UPLOAD-Conversion-Aktionen erstellen können, unterstützt die API das Hochladen von Transaktionen für Ladenverkäufe.

  • STORE_SALES
  • STORE_SALES_DIRECT_UPLOAD

Sonstige

Die folgenden Conversion-Aktionstypen sind in der Google Ads API schreibgeschützt und werden zu Berichtszwecken bereitgestellt.

  • 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

Unbekannt

Wenn Ihr Google Ads-Konto andere Arten von Conversion-Aktionen enthält, werden Abfragen und Berichte unter Umständen Conversion-Aktionen zurückgeben, bei denen ConversionAction.type den Wert UNKNOWN hat. Die API unterstützt die Verwaltung dieser Conversion-Aktionen nicht, gibt sie aber in Berichten zurück, um vollständige Ergebnisse für wichtige Conversion-Messwerte wie metrics.conversions und metrics.conversions_value bereitzustellen.

Codebeispiel

Im folgenden Codebeispiel wird gezeigt, wie Sie eine neue Conversion-Aktion erstellen. Insbesondere wird eine Conversion-Aktion erstellt, bei der type auf UPLOAD_CLICKS festgelegt ist. Dies entspricht dem Ablauf in der Google Ads-Benutzeroberfläche wie beim Erstellen einer neuen Conversion-Aktion mit Import > Manueller Import mit API oder Uploads > Klick-Conversions erfassen. Außerdem wird category auf DEFAULT gesetzt.

Es gelten die folgenden Standardeinstellungen:

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;
}
      

Sie finden dieses Beispiel auch im Remarketing-Ordner Ihrer Clientbibliothek und in der Sammlung mit Codebeispielen: Codebeispiel für Conversion-Aktionen hinzufügen.

Anforderungen

Google Ads und die Google Ads API unterstützen viele verschiedene Conversion-Aktionen. Daher variieren einige Validierungsregeln je nach type der Aktion.

Der mit Abstand häufigste Fehler beim Erstellen einer Conversion-Aktion ist DUPLICATE_NAME. Verwenden Sie für jede Conversion-Aktion einen eindeutigen Namen.

Hier einige Tipps zum Festlegen der ConversionAction-Felder:

Alle enum-Felder
Der Versuch, ein Enum-Feld auf UNKNOWN festzulegen, führt zu einem RequestError.INVALID_ENUM_VALUE-Fehler.
app_id
Das Attribut app_id ist unveränderlich und kann nur beim Erstellen einer neuen App-Conversion festgelegt werden.
attribution_model_settings
Wenn Sie für diese Option eine eingestellte Option festlegen, wird der Fehler CANNOT_SET_RULE_BASED_ATTRIBUTION_MODELS zurückgegeben. Google Ads unterstützt nur GOOGLE_ADS_LAST_CLICK und GOOGLE_SEARCH_ATTRIBUTION_DATA_DRIVEN.
click_through_lookback_window_days

Wenn Sie für dieses Attribut einen Wert außerhalb des zulässigen Bereichs festlegen, wird der Fehler RangeError.TOO_LOW oder RangeError.TOO_HIGH zurückgegeben.

Dieses Attribut muss für die Conversion-Aktion AD_CALL oder WEBSITE_CALL im Bereich [1,60] liegen. Bei den meisten anderen Conversion-Aktionen ist der zulässige Bereich [1,30].

include_in_conversions_metric

Das Festlegen dieses Werts in einem create- oder update-Vorgang schlägt mit dem Fehler FieldError.IMMUTABLE_FIELD fehl. Legen Sie stattdessen primary_for_goal wie im Leitfaden zu Conversion-Zielvorhaben beschrieben fest.

phone_call_duration_seconds

Der Versuch, dieses Attribut für eine Conversion-Aktion festzulegen, die nicht für Anrufe bestimmt ist, führt zu einem FieldError.VALUE_MUST_BE_UNSET-Fehler.

type

Das Attribut type ist unveränderlich und kann nur beim Erstellen einer neuen Conversion festgelegt werden.

Wenn Sie eine Conversion-Aktion aktualisieren, bei der type gleich UNKNOWN ist, wird ein MutateError.MUTATE_NOT_ALLOWED-Fehler ausgegeben.

value_settings

Für value_settings für eine Conversion-Aktion vom Typ WEBSITE_CALL oder AD_CALL muss always_use_default_value auf true festgelegt sein. Wenn Sie beim Erstellen oder Aktualisieren dieses Werts den Wert false angeben, wird der Fehler INVALID_VALUE zurückgegeben.

view_through_lookback_window_days

Wenn Sie für dieses Attribut einen Wert außerhalb des zulässigen Bereichs festlegen, wird der Fehler RangeError.TOO_LOW oder RangeError.TOO_HIGH zurückgegeben. Bei den meisten Conversion-Aktionen ist der zulässige Bereich [1,30].

Dieses Attribut kann nicht für AD_CALL- oder WEBSITE_CALL-Conversion-Aktionen festgelegt werden. Die Angabe eines Werts führt zum Fehler VALUE_MUST_BE_UNSET.