Maksimum Performans kampanyaları, öğelerle ilgili bazı benzersiz özelliklere sahiptir.
- Farklı türlerdeki öğeler için minimum sayı şartı vardır.
- Öğeler, Maksimum Performans kampanyalarına özgü olan
AssetGroupadlı bir koleksiyonda gruplandırılır. - Bazı öğeler makine öğrenimi tarafından otomatik olarak oluşturulabilir.
Marka kuralları: işletme adı ve logo bağlantısı
Maksimum Performans kampanyasındaki öğelerin çoğu öğe grupları içinde düzenlenirken markanızın kimliğini temsil eden temel öğeler (özellikle işletme adı ve işletme logosu), kampanyanız için marka kuralları etkinleştirilmişse farklı şekilde ele alınır.
Bu marka yönergeleri öğeleri, öğe grubu düzeyinde değil doğrudan kampanya düzeyinde bağlanır. Bu işlem, CampaignAsset kaynağı kullanılarak yapılır. Öğeyi kampanyaya bağlar ve uygun AssetFieldType değerini belirtirsiniz:
* `BUSINESS_NAME` for the Business Name asset (which is a Text Asset).
* `LOGO` for the Business Logo asset (which is an Image Asset).
Kampanya düzeyindeki bu bağlantı, Maksimum Performans kampanyasındaki tüm öğe gruplarında tutarlı marka temsili sağlar.
Kod örneği
Aşağıdaki kod snippet'inde, yeni bir istekte gerekli tekrarlanan öğelerin nasıl oluşturulacağı gösterilmektedir:
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.V22.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: GoogleAdsClient, customer_id: str, texts: List[str] ) -> List[str]: """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: GoogleAdsServiceClient = client.get_service( "GoogleAdsService" ) operations: List[MutateOperation] = [] for text in texts: mutate_operation: MutateOperation = client.get_type("MutateOperation") asset: Asset = mutate_operation.asset_operation.create asset.text_asset.text = text operations.append(mutate_operation) # Send the operations in a single Mutate request. response: MutateGoogleAdsResponse = googleads_service.mutate( customer_id=customer_id, mutate_operations=operations, ) asset_resource_names: List[str] = [] 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::V22::Services::GoogleAdsService::MutateOperation ->new({ assetOperation => Google::Ads::GoogleAds::V22::Services::AssetService::AssetOperation-> new({ create => Google::Ads::GoogleAds::V22::Resources::Asset->new({ textAsset => Google::Ads::GoogleAds::V22::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; }
Otomatik olarak oluşturulmuş öğeler
Makine öğrenimini kullanan Google otomasyonu, tüm alakalı kanalları kapsamak için gerektiğinde ek öğeler oluşturur. Öğeler, reklamınızın yayınlandığı Google reklam kanalına (ör. YouTube, Gmail veya Arama) göre otomatik olarak karıştırılıp eşleştirilir. Bu ayarları yönetme hakkında daha fazla bilgi için öğe otomasyonu ayarları kılavuzuna bakın.
Metin öğeleri
Hesabınızdaki bir sayfa feed'ini Maksimum Performans kampanyasıyla ilişkilendirerek otomatik olarak öğe oluşturabilirsiniz.
Sayfa feed'ini bir kampanyaya bağlamak için Dinamik Arama Ağı reklamlarında kullanılan süreci uygulayın:
- Web sitenizin her sayfası için öğeler oluşturun
- Sayfa feed'i öğelerini AssetSet'e paketleme
- Öğe grubunu bir kampanyayla ilişkilendirme
Bir sayfa feed'i ilişkilendirdikten sonra, AssetAutomationSetting türündeki
TEXT_ASSET_AUTOMATION öğesinin OPTED_IN olarak ayarlandığından emin olun.
Kampanyayı oluştururken AssetAutomationSetting ayarını yapmadıysanız bu, varsayılan ayardır.
Bu ayarı kullanırsanız kampanyanız, performansı iyileştireceği tahmin edildiğinde reklamları özelleştirmek amacıyla açılış sayfanızın içeriğini, alanınızı ve sağlanan öğeleri kullanabilir. Bu ayarı OPTED-IN olarak bırakmanızı öneririz.
Video öğeleri
Maksimum Performans öğe grubunuza video eklemezseniz öğe grubunuzdaki öğelerden bir veya daha fazla video öğesi oluşturulabilir. Maksimum Performans kampanyanızda, otomatik olarak oluşturulan videoların yayınlanmasını artık istemiyorsanız kendi özel videonuzu yükleyebilirsiniz. Bu durumda, otomatik olarak oluşturulan videoların yayını durdurulur.
Akıllı otomasyon, video yönünü ayarlayarak ve önemli anları vurgulamak için videoları akıllıca kısaltarak YouTube video öğelerinizi iyileştirebilir. Orijinal video öğelerinizi korumayı tercih ediyorsanız GENERATE_ENHANCED_YOUTUBE_VIDEOS türündeki AssetAutomationSetting öğesini OPTED_OUT olarak ayarlayın.