Kampanye Performa Maksimal memiliki beberapa karakteristik unik terkait aset.
- Ada jumlah minimum aset dari berbagai jenis yang diperlukan.
- Aset dikelompokkan dalam koleksi yang disebut
AssetGroup
, yang unik untuk kampanye Performa Maksimal. - Beberapa aset dapat dibuat secara otomatis oleh machine learning.
Contoh kode
Cuplikan kode berikut mengilustrasikan pembuatan aset berulang yang diperlukan dalam permintaan baru:
Java
/** Creates multiple text assets and returns the list of resource names. */ private List<String> createMultipleTextAssets( GoogleAdsClient googleAdsClient, long customerId, List<String> texts) { List<MutateOperation> mutateOperations = new ArrayList<>(); for (String text : texts) { Asset asset = Asset.newBuilder().setTextAsset(TextAsset.newBuilder().setText(text)).build(); AssetOperation assetOperation = AssetOperation.newBuilder().setCreate(asset).build(); mutateOperations.add(MutateOperation.newBuilder().setAssetOperation(assetOperation).build()); } List<String> assetResourceNames = new ArrayList<>(); // Creates the service client. try (GoogleAdsServiceClient googleAdsServiceClient = googleAdsClient.getLatestVersion().createGoogleAdsServiceClient()) { // Sends the operations in a single Mutate request. MutateGoogleAdsResponse response = googleAdsServiceClient.mutate(Long.toString(customerId), mutateOperations); for (MutateOperationResponse result : response.getMutateOperationResponsesList()) { if (result.hasAssetResult()) { assetResourceNames.add(result.getAssetResult().getResourceName()); } } printResponseDetails(response); } return assetResourceNames; }
C#
/// <summary> /// Creates multiple text assets and returns the list of resource names. /// </summary> /// <param name="client">The Google Ads Client.</param> /// <param name="customerId">The customer's ID.</param> /// <param name="texts">The texts to add.</param> /// <returns>A list of asset resource names.</returns> private List<string> CreateMultipleTextAssets( GoogleAdsClient client, long customerId, string[] texts) { // Get the GoogleAdsService. GoogleAdsServiceClient googleAdsServiceClient = client.GetService(Services.V19.GoogleAdsService); MutateGoogleAdsRequest request = new MutateGoogleAdsRequest() { CustomerId = customerId.ToString() }; foreach (string text in texts) { request.MutateOperations.Add( new MutateOperation() { AssetOperation = new AssetOperation() { Create = new Asset() { TextAsset = new TextAsset() { Text = text } } } } ); } // Send the operations in a single Mutate request. MutateGoogleAdsResponse response = googleAdsServiceClient.Mutate(request); List<string> assetResourceNames = new List<string>(); foreach (MutateOperationResponse operationResponse in response.MutateOperationResponses) { MutateAssetResult assetResult = operationResponse.AssetResult; assetResourceNames.Add(assetResult.ResourceName); } PrintResponseDetails(response); return assetResourceNames; }
PHP
private static function createMultipleTextAssets( GoogleAdsClient $googleAdsClient, int $customerId, array $texts ): array { // Here again, we use the GoogleAdService to create multiple text assets in a single // request. $operations = []; foreach ($texts as $text) { // Creates a mutate operation for a text asset. $operations[] = new MutateOperation([ 'asset_operation' => new AssetOperation([ 'create' => new Asset(['text_asset' => new TextAsset(['text' => $text])]) ]) ]); } // Issues a mutate request to add all assets. $googleAdsService = $googleAdsClient->getGoogleAdsServiceClient(); /** @var MutateGoogleAdsResponse $mutateGoogleAdsResponse */ $mutateGoogleAdsResponse = $googleAdsService->mutate(MutateGoogleAdsRequest::build($customerId, $operations)); $assetResourceNames = []; foreach ($mutateGoogleAdsResponse->getMutateOperationResponses() as $response) { /** @var MutateOperationResponse $response */ $assetResourceNames[] = $response->getAssetResult()->getResourceName(); } self::printResponseDetails($mutateGoogleAdsResponse); return $assetResourceNames; }
Python
def create_multiple_text_assets(client, customer_id, texts): """Creates multiple text assets and returns the list of resource names. Args: client: an initialized GoogleAdsClient instance. customer_id: a client customer ID. texts: a list of strings, each of which will be used to create a text asset. Returns: asset_resource_names: a list of asset resource names. """ # Here again we use the GoogleAdService to create multiple text # assets in a single request. googleads_service = client.get_service("GoogleAdsService") operations = [] for text in texts: mutate_operation = client.get_type("MutateOperation") asset = mutate_operation.asset_operation.create asset.text_asset.text = text operations.append(mutate_operation) # Send the operations in a single Mutate request. response = googleads_service.mutate( customer_id=customer_id, mutate_operations=operations, ) asset_resource_names = [] for result in response.mutate_operation_responses: if result._pb.HasField("asset_result"): asset_resource_names.append(result.asset_result.resource_name) print_response_details(response) return asset_resource_names
Ruby
# Creates multiple text assets and returns the list of resource names. def create_multiple_text_assets(client, customer_id, texts) operations = texts.map do |text| client.operation.mutate do |m| m.asset_operation = client.operation.create_resource.asset do |asset| asset.text_asset = client.resource.text_asset do |text_asset| text_asset.text = text end end end end # Send the operations in a single Mutate request. response = client.service.google_ads.mutate( customer_id: customer_id, mutate_operations: operations, ) asset_resource_names = [] response.mutate_operation_responses.each do |result| if result.asset_result asset_resource_names.append(result.asset_result.resource_name) end end print_response_details(response) asset_resource_names end
Perl
sub create_multiple_text_assets { my ($api_client, $customer_id, $texts) = @_; # Here again we use the GoogleAdService to create multiple text assets in a # single request. my $operations = []; foreach my $text (@$texts) { # Create a mutate operation for a text asset. push @$operations, Google::Ads::GoogleAds::V19::Services::GoogleAdsService::MutateOperation ->new({ assetOperation => Google::Ads::GoogleAds::V19::Services::AssetService::AssetOperation-> new({ create => Google::Ads::GoogleAds::V19::Resources::Asset->new({ textAsset => Google::Ads::GoogleAds::V19::Common::TextAsset->new({ text => $text })})})}); } # Issue a mutate request to add all assets. my $mutate_google_ads_response = $api_client->GoogleAdsService()->mutate({ customerId => $customer_id, mutateOperations => $operations }); my $asset_resource_names = []; foreach my $response (@{$mutate_google_ads_response->{mutateOperationResponses}}) { push @$asset_resource_names, $response->{assetResult}{resourceName}; } print_response_details($mutate_google_ads_response); return $asset_resource_names; }
Aset yang otomatis dibuat
Otomatisasi Google yang menggunakan machine learning menghasilkan aset tambahan sesuai kebutuhan untuk mencakup semua saluran yang relevan. Aset digabungkan dan dicocokkan secara otomatis berdasarkan saluran Google Ads (seperti YouTube, Gmail, atau Penelusuran) yang digunakan untuk menayangkan iklan Anda.
Aset teks
Anda dapat mengaitkan feed halaman di akun dengan kampanye Performa Maksimal untuk membuat aset secara otomatis.
Untuk menautkan feed halaman dengan kampanye, gunakan proses yang sama seperti yang digunakan untuk Iklan Penelusuran Dinamis:
- Membuat aset untuk setiap halaman situs
- Memaketkan aset feed halaman ke dalam AssetSet
- Mengaitkan AssetSet dengan kampanye
Setelah mengaitkan feed halaman, pastikan AssetAutomationSetting
dari jenis
TEXT_ASSET_AUTOMATION
ditetapkan ke OPTED_IN
.
Ini adalah setelan default jika Anda tidak menetapkan AssetAutomationSetting
saat
membuat kampanye.
Dengan setelan ini, kampanye Anda dapat menggunakan konten dari halaman landing, domain, dan aset yang diberikan untuk menyesuaikan iklan jika diprediksi akan meningkatkan performa. Sebaiknya biarkan ini sebagai OPTED-IN
.
Aset video
Jika Anda tidak menambahkan video ke grup aset Performa Maksimal, satu atau beberapa aset video mungkin dibuat dari aset dalam grup aset Anda. Jika tidak ingin lagi menayangkan video yang dibuat secara otomatis di kampanye Performa Maksimal, Anda dapat mengupload video kustom Anda sendiri, dan video yang dibuat secara otomatis akan berhenti ditayangkan.
Otomatisasi cerdas dapat meningkatkan kualitas aset
video YouTube Anda dengan menyesuaikan orientasi
video dan memperpendeknya secara cerdas untuk menyoroti momen-momen penting. Jika Anda
lebih memilih untuk mempertahankan aset video asli, tetapkan
AssetAutomationSetting
dari
jenis GENERATE_ENHANCED_YOUTUBE_VIDEOS
ke OPTED_OUT
.