Anda harus mengaktifkan tracking konversi di akun konversi Google Ads untuk mencatat konversi. Panduan ini memberikan detail tentang cara mengonfirmasi apakah tracking konversi diaktifkan, mengaktifkannya jika belum diaktifkan, dan mengambil informasi tentang tindakan konversi yang ada.
Sebagian besar tindakan konversi juga memerlukan langkah tambahan dari Anda untuk melacaknya. Untuk mengetahui informasi selengkapnya tentang berbagai jenis tindakan konversi dan persyaratannya, lihat panduan Membuat tindakan konversi.
Bersiap memberikan izin
Anda harus mengonfirmasi bahwa Anda memiliki izin untuk membagikan data konversi kepada Google. Hal ini dapat dilakukan dengan salah satu dari 2 cara berikut:
- Mengonfigurasi setelan izin default tingkat akun. Di UI Google Ads, klik Alat -> Pengelola Data -> Setelan izin -> Setelan izin default.
- Menetapkan kolom ClickConversion.consent pada setiap konversi yang diimpor.
Menyiapkan situs untuk melacak konversi
Jika Anda memulai integrasi impor konversi offline, langkah pertama adalah mengikuti langkah-langkah dalam panduan Mengonfigurasi tag Google untuk konversi yang disempurnakan untuk lead guna mengonfigurasi situs Anda untuk melacak konversi yang disempurnakan untuk lead. Anda juga dapat menggunakan Google Tag Manager untuk mengonfigurasi situs Anda dengan mengikuti langkah-langkah dalam panduan Mengonfigurasi Google Tag Manager untuk konversi yang disempurnakan untuk lead.
Mengaktifkan tracking konversi di akun konversi Google Ads
Mengambil informasi tentang penyiapan tracking konversi
Anda dapat memeriksa penyiapan tracking konversi akun dan mengonfirmasi bahwa tracking
konversi diaktifkan dengan membuat kueri resource Customer
untuk ConversionTrackingSetting.
Kirim kueri berikut dengan
GoogleAdsService.SearchStream:
SELECT
customer.conversion_tracking_setting.google_ads_conversion_customer,
customer.conversion_tracking_setting.conversion_tracking_status,
customer.conversion_tracking_setting.conversion_tracking_id,
customer.conversion_tracking_setting.cross_account_conversion_tracking_id
FROM customer
Kolom google_ads_conversion_customer menunjukkan akun Google Ads yang membuat dan mengelola konversi untuk pelanggan ini. Untuk pelanggan yang menggunakan
tracking konversi lintas-akun,
kolom ini adalah ID akun pengelola. ID pelanggan konversi Google Ads harus diberikan sebagai customer_id dalam permintaan Google Ads API untuk membuat dan mengelola konversi.
Perhatikan bahwa kolom ini diisi meskipun tracking konversi tidak diaktifkan.
Kolom
conversion_tracking_status
menunjukkan apakah tracking konversi diaktifkan dan apakah akun
menggunakan tracking konversi lintas-akun.
Membuat tindakan konversi di bawah pelanggan konversi Google Ads
Jika nilai conversion_tracking_status adalah NOT_CONVERSION_TRACKED, tracking konversi tidak diaktifkan untuk akun tersebut. Aktifkan tracking konversi
dengan membuat setidaknya satu ConversionAction di
akun konversi Google Ads, seperti dalam contoh berikut. Atau, Anda
dapat membuat tindakan konversi di UI dengan mengikuti petunjuk di
Pusat Bantuan untuk
jenis konversi yang ingin diaktifkan.
Perhatikan bahwa konversi yang disempurnakan diaktifkan secara otomatis saat dikirim melalui Google Ads API, tetapi dapat dinonaktifkan melalui UI Google Ads.
Contoh kode
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.V24.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: GoogleAdsClient, customer_id: str) -> None: conversion_action_service: ConversionActionServiceClient = ( client.get_service("ConversionActionService") ) # Create the operation. conversion_action_operation: ConversionActionOperation = client.get_type( "ConversionActionOperation" ) # Create conversion action. conversion_action: ConversionAction = 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: ConversionAction.ValueSettings = ( conversion_action.value_settings ) value_settings.default_value = 15.0 value_settings.always_use_default_value = True # Add the conversion action. conversion_action_response: MutateConversionActionsResponse = ( 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::V24::Resources::ConversionAction->new({ name => $conversion_action_name, category => DEFAULT, type => WEBPAGE, status => ENABLED, viewThroughLookbackWindowDays => 15, valueSettings => Google::Ads::GoogleAds::V24::Resources::ValueSettings->new({ defaultValue => 23.41, alwaysUseDefaultValue => "true" })}); # Create a conversion action operation. my $conversion_action_operation = Google::Ads::GoogleAds::V24::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; }
curl
Pastikan conversion_action_type ditetapkan ke nilai
ConversionActionType yang benar.
Untuk panduan selengkapnya tentang cara membuat tindakan konversi di Google Ads API, lihat Membuat Tindakan Konversi.
Mengambil tindakan konversi yang ada
Anda dapat mengambil detail untuk tindakan konversi yang ada dengan mengirimkan kueri berikut. Pastikan ID pelanggan dalam permintaan ditetapkan ke pelanggan konversi Google Ads
yang Anda identifikasi di atas, dan jenis tindakan konversi ditetapkan
ke nilai yang benar
ConversionActionType.
SELECT
conversion_action.resource_name,
conversion_action.name,
conversion_action.status
FROM conversion_action
WHERE conversion_action.type = 'INSERT_CONVERSION_ACTION_TYPE'
Tracking konversi lintas-akun
Tracking konversi lintas-akun memungkinkan akun Google Ads mengimpor konversi atas nama akun lain, yang mungkin telah menayangkan iklan yang menghasilkan konversi. Hal ini dapat membantu menyederhanakan integrasi Anda dengan memungkinkan Anda menggabungkan akun yang membuat permintaan impor.
Mengaktifkan tracking konversi lintas-akun di Google Ads API
Anda dapat menggunakan Google Ads API untuk memilih tracking lintas-konversi saat membuat atau memperbarui akun klien.
Di resource Customer, tetapkan kolom
conversion_tracking_setting.google_ads_conversion_customer
ke
nama resource akun pengelola yang harus mengelola tindakan konversi atas nama akun klien.
Permintaan yang mengubah pelanggan konversi akun klien harus dikirim oleh akun pengelola yang menjadi pelanggan konversi baru untuk klien. Lakukan hal ini dengan menetapkan login-customer-id ke ID akun pengelola.
- Akun klien akan mengadopsi aturan nilai konversi default, dan sasaran siklus proses pelanggan default dari pengelola tracking konversi barunya.
- Kampanye yang menargetkan tindakan konversi tertentu akan beralih menggunakan sasaran konversi default akun pengelola konversi. Jika Anda terus menargetkan tindakan konversi tertentu, hal tersebut dapat menghasilkan perilaku yang tidak konsisten, karena akun pengelola mungkin tidak memiliki sasaran yang sama dengan akun klien. Pastikan kampanye Anda dioptimalkan untuk sasaran yang tepat.
- Jika akun dimiliki oleh lebih dari satu akun pengelola, akun tersebut hanya dapat menggunakan tindakan konversi dari satu pengelola. Jika tidak ada akun tracking konversi yang ditentukan, akun akan menggunakan dirinya sendiri sebagai akun tracking konversi secara default.
Mengimpor konversi di seluruh akun
Dengan tracking lintas-akun diaktifkan, akun klien dan pengelola dapat mengimpor konversi atas nama akun penayangan. Hal ini memungkinkan Anda menyederhanakan logika impor sehingga Anda tidak perlu menentukan akun penayangan untuk setiap konversi pada waktu impor, Anda hanya dapat memilih satu akun dari hierarki akun untuk mengimpor semua konversi.
Agar berhasil mengupload konversi, akun yang mengupload harus memiliki akses ke tindakan konversi. Dalam hierarki tracking lintas-akun, akun yang mengupload memiliki akses ke tindakan jika merupakan induk (pengelola) atau turunan dari pemilik tindakan konversi di hierarki akun.
Diagram berikut mengilustrasikan struktur otorisasi untuk mengimpor konversi. Di sini, C1 adalah akun klien yang menayangkan iklan yang menghasilkan konversi, dan M2 adalah pemilik tindakan konversi dan induk tracking konversi C1. Akun yang ditandai dengan warna hijau diizinkan untuk mengimpor konversi atas nama C1, sedangkan akun yang ditandai dengan warna merah tidak diizinkan.

Membuat tindakan konversi
Untuk mengukur konversi, siapkan a
ConversionAction untuk the
type of
tindakan konversi yang ingin Anda lacak. Misalnya, pembelian online dan panggilan telepon memerlukan tindakan konversi yang berbeda.
Cara terbaik untuk menyiapkan tindakan konversi baru di API adalah menggunakan
contoh kode Tambahkan Tindakan Konversi di bawah. Contoh ini menangani
semua tugas autentikasi latar belakang untuk Anda, dan memandu Anda membuat
a ConversionAction.
Sebagian besar tindakan konversi juga memerlukan langkah tambahan dari Anda untuk melacaknya. Misalnya, untuk melacak konversi di situs Anda, Anda harus menambahkan cuplikan kode yang disebut tagke halaman konversi di situs Anda. Untuk mengetahui persyaratan mendetail dari jenis tindakan konversi lainnya, lihat artikel Pusat Bantuan kami.
Jika Anda menggunakan tracking konversi lintas-akun, ConversionActionService akan menampilkan tindakan konversi berikut:
- Semua tindakan konversi yang ditentukan oleh akun pengelola yang digunakan oleh akun untuk tracking konversi lintas-akun
- Semua tindakan konversi yang telah mengakumulasikan statistik pelanggan, termasuk tindakan yang ditentukan sistem, dan tindakan yang dimiliki oleh pengelola meskipun pengelola tersebut kemudian membatalkan tautan
- Semua tindakan yang telah ditentukan pelanggan di akunnya sendiri
- Konversi Analytics yang dibuat di properti Google Analytics yang ditautkan.
Hal ini mencakup tindakan untuk konversi Analytics yang tidak diimpor ke Google Ads,
yang memiliki status
HIDDEN.
Contoh kode
Contoh kode berikut akan memandu Anda menyelesaikan proses pembuatan tindakan konversi baru. Secara khusus, contoh ini membuat tindakan konversi dengan
type yang ditetapkan ke
UPLOAD_CLICKS.
Contoh ini juga menetapkan category
ke DEFAULT.
Setelan default berikut berlaku:
Google Ads API menetapkan kolom
primary_for_goalsecara otomatis, tetapi Anda dapat menetapkan kolom ini secara eksplisit untuk mengontrol dampak tindakan konversi terhadap pelaporan dan bidding di akun Anda saat digabungkan dengan sasaran konversi Anda.Google Ads API menetapkan
counting_typesecara otomatis keMANY_PER_CLICKLihat Tentang opsi penghitungan konversi untuk mengetahui detail selengkapnya.Google Ads API menetapkan model atribusi menjadi Berbasis data dengan menetapkan kolom
attribution_model_settingske nilaiGOOGLE_SEARCH_ATTRIBUTION_DATA_DRIVENdariAttributionModel. Lihat artikel Pusat Bantuan ini untuk mempelajari model atribusi lebih lanjut.
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.V24.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: GoogleAdsClient, customer_id: str) -> None: conversion_action_service: ConversionActionServiceClient = ( client.get_service("ConversionActionService") ) # Create the operation. conversion_action_operation: ConversionActionOperation = client.get_type( "ConversionActionOperation" ) # Create conversion action. conversion_action: ConversionAction = 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: ConversionAction.ValueSettings = ( conversion_action.value_settings ) value_settings.default_value = 15.0 value_settings.always_use_default_value = True # Add the conversion action. conversion_action_response: MutateConversionActionsResponse = ( 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::V24::Resources::ConversionAction->new({ name => $conversion_action_name, category => DEFAULT, type => WEBPAGE, status => ENABLED, viewThroughLookbackWindowDays => 15, valueSettings => Google::Ads::GoogleAds::V24::Resources::ValueSettings->new({ defaultValue => 23.41, alwaysUseDefaultValue => "true" })}); # Create a conversion action operation. my $conversion_action_operation = Google::Ads::GoogleAds::V24::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; }
curl
Anda dapat melihat contoh ini di folder Pemasaran Ulang pada library klien dan di kumpulan contoh kode: Contoh kode Tambahkan Tindakan Konversi contoh.
Validasi
Google Ads dan Google Ads API mendukung berbagai tindakan konversi, sehingga beberapa
aturan validasi bervariasi berdasarkan type
tindakan.
Error yang paling umum saat membuat tindakan konversi adalah
DUPLICATE_NAME.
Pastikan Anda menggunakan nama unik untuk setiap tindakan konversi.
Berikut beberapa tips untuk menetapkan kolom ConversionAction:
- Semua kolom enum
- Mencoba menetapkan kolom enum apa pun ke
UNKNOWNakan menghasilkan errorRequestError.INVALID_ENUM_VALUE. app_id- Atribut
app_idtidak dapat diubah dan hanya dapat ditetapkan saat membuat konversi aplikasi baru. attribution_model_settings- Menetapkan atribut ini ke opsi yang tidak digunakan lagi
akan menghasilkan
CANNOT_SET_RULE_BASED_ATTRIBUTION_MODELSerror. Google Ads hanya mendukungGOOGLE_ADS_LAST_CLICKdanGOOGLE_SEARCH_ATTRIBUTION_DATA_DRIVEN. click_through_lookback_window_daysMenetapkan atribut ini ke nilai di luar rentang yang diizinkan akan menghasilkan error
RangeError.TOO_LOWatauRangeError.TOO_HIGH.Atribut ini harus berada dalam rentang
[1,60]untuk tindakan konversiAD_CALLatauWEBSITE_CALL. Untuk sebagian besar tindakan konversi lainnya, rentang yang diizinkan adalah[1,30].include_in_conversions_metricMenetapkan nilai ini dalam operasi
createatauupdateakan gagal dengan errorFieldError.IMMUTABLE_FIELD. Sebagai gantinya, tetapkanprimary_for_goalseperti yang dijelaskan dalam panduan Sasaran konversi.phone_call_duration_secondsMencoba menetapkan atribut ini pada tindakan konversi yang bukan untuk panggilan akan menghasilkan error
FieldError.VALUE_MUST_BE_UNSET.typeAtribut
typetidak dapat diubah dan hanya dapat ditetapkan saat membuat konversi baru.Memperbarui tindakan konversi dengan
typeyang sama denganUNKNOWNakan menghasilkan errorMutateError.MUTATE_NOT_ALLOWED.value_settingsvalue_settingsuntuk tindakan konversiWEBSITE_CALLatauAD_CALLharus memilikialways_use_default_valueyang ditetapkan ketrue. Menentukan nilaifalsesaat membuat atau memperbarui nilai ini akan menghasilkan errorINVALID_VALUE.view_through_lookback_window_daysMenetapkan atribut ini ke nilai di luar rentang yang diizinkan akan menghasilkan error
RangeError.TOO_LOWatauRangeError.TOO_HIGH. Untuk sebagian besar tindakan konversi, rentang yang diizinkan adalah[1,30].Atribut ini tidak dapat ditetapkan pada tindakan konversi
AD_CALLatauWEBSITE_CALL. Menentukan nilai akan menghasilkan errorVALUE_MUST_BE_UNSET.