Chiến dịch Tối đa hoá hiệu suất có một số đặc điểm riêng biệt về tài sản.
- Phải có số lượng tối thiểu các loại thành phần.
- Các tài sản được nhóm lại với nhau trong một tập hợp có tên là
AssetGroup
(chỉ dành cho chiến dịch Tối đa hoá hiệu suất) . - Một số thành phần có thể được tạo tự động bằng công nghệ học máy.
Ví dụ về mã
Đoạn mã sau minh hoạ cách tạo các thành phần lặp lại cần thiết trong một yêu cầu mới:
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.V17.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::V17::Services::GoogleAdsService::MutateOperation ->new({ assetOperation => Google::Ads::GoogleAds::V17::Services::AssetService::AssetOperation-> new({ create => Google::Ads::GoogleAds::V17::Resources::Asset->new({ textAsset => Google::Ads::GoogleAds::V17::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; }
Thành phần được tạo tự động
Tính năng tự động hoá của Google sử dụng công nghệ học máy tạo ra các thành phần bổ sung khi cần để bao gồm tất cả các kênh có liên quan. Các thành phần được tạo tự động kết hợp và so khớp dựa trên kênh quảng cáo của Google (chẳng hạn như YouTube, Gmail, hoặc Mạng Tìm kiếm) mà quảng cáo của bạn đang được phân phát.
Thành phần văn bản
Bạn có thể liên kết nguồn cấp dữ liệu trang trong tài khoản của mình với Chiến dịch Tối đa hoá hiệu suất để tự động tạo thành phần.
Để liên kết nguồn cấp dữ liệu trang với chiến dịch, hãy sử dụng quy trình tương tự như đã sử dụng cho Quảng cáo tìm kiếm động:
- Tạo thành phần cho mỗi trang trên trang web của bạn
- Đóng gói thành phần nguồn cấp dữ liệu trên trang vào AssetSet
- Liên kết AssetSet với một chiến dịch
Sau khi bạn liên kết nguồn cấp dữ liệu trang, hãy đảm bảo thuộc loại AssetAutomationSetting
TEXT_ASSET_AUTOMATION
được đặt thành OPTED_IN
.
Đây là chế độ cài đặt mặc định nếu bạn không đặt AssetAutomationSetting
khi
tạo chiến dịch.
Khi sử dụng chế độ cài đặt này, chiến dịch có thể sử dụng nội dung trên trang đích của bạn,
miền và các thành phần được cung cấp để tuỳ chỉnh quảng cáo khi được dự đoán là sẽ cải thiện
hiệu suất. Bạn nên để mục này là OPTED-IN
.
Nội dung video
Nếu bạn không thêm video vào nhóm thành phần của chiến dịch Tối đa hoá hiệu suất, thì một hoặc nhiều thành phần video có thể được tạo từ các thành phần trong nhóm thành phần của bạn. Nếu bạn không muốn phân phát video được tạo tự động trong chiến dịch Tối đa hoá hiệu suất, bạn có thể tải video tuỳ chỉnh của riêng mình lên và các video được tạo tự động sẽ ngừng phân phát.