تتضمّن "حملات الأداء الأفضل" بعض الخصائص الفريدة المتعلّقة بمواد العرض.
- هناك حدّ أدنى لعدد مواد العرض المطلوبة من أنواع مختلفة.
- يتم تجميع مواد العرض معًا في مجموعة تُعرف باسم
AssetGroup
، وهي ميزة فريدة في "حملات الأداء الأفضل". - يمكن إنشاء بعض مواد العرض تلقائيًا من خلال تعلُّم الآلة.
مثال على الرمز
يوضّح مقتطف الرمز التالي كيفية إنشاء مواد العرض المتكرّرة اللازمة في طلب جديد:
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.V20.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::V20::Services::GoogleAdsService::MutateOperation ->new({ assetOperation => Google::Ads::GoogleAds::V20::Services::AssetService::AssetOperation-> new({ create => Google::Ads::GoogleAds::V20::Resources::Asset->new({ textAsset => Google::Ads::GoogleAds::V20::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; }
مواد عرض منشأة تلقائيًا
تنشئ الأساليب المبرمَجة من Google التي تستخدم تعلُّم الآلة مواد عرض إضافية حسب الحاجة لتغطية جميع القنوات ذات الصلة. ويتم مزج مواد العرض هذه ومطابقتها تلقائيًا استنادًا إلى قناة إعلانات Google (سواء YouTube أو Gmail أو "بحث Google" أو غيرها) التي يتم عرض إعلانك عليها.
مواد العرض النصية
يمكنك ربط خلاصة صفحة في حسابك بإحدى "حملات الأداء الأفضل" من أجل إنشاء مواد عرض تلقائيًا.
لربط خلاصة صفحة بحملة، اتّبِع العملية نفسها المستخدَمة في الإعلانات الديناميكية على شبكة البحث:
- إنشاء مواد عرض لكل صفحة من صفحات موقعك الإلكتروني
- تجميع مواد عرض خلاصة الصفحة في AssetSet
- ربط مجموعة مواد العرض بحملة
بعد ربط خلاصة صفحة، تأكَّد من ضبط AssetAutomationSetting
من النوع
TEXT_ASSET_AUTOMATION
على OPTED_IN
.
هذا هو الإعداد التلقائي في حال عدم ضبط AssetAutomationSetting
عند إنشاء الحملة.
يعني استخدام هذا الإعداد أنّ حملتك يمكنها استخدام محتوى من صفحتك المقصودة ونطاقك ومواد العرض المقدَّمة لتخصيص الإعلانات عندما يكون من المتوقّع أن تؤدّي إلى تحسين الأداء. ننصحك بإبقاء هذا الخيار على OPTED-IN
.
مواد عرض الفيديو
في حال عدم إضافة فيديو إلى مجموعة مواد عرض "حملة الأداء الأفضل"، قد يتم إنشاء مادة عرض فيديو واحدة أو أكثر من مواد العرض في مجموعة مواد العرض الخاصة بك. إذا لم تعد تريد عرض الفيديوهات المُنشأة تلقائيًا في "حملة الأداء الأفضل"، يمكنك تحميل الفيديو المخصّص التابع لك، وسيتوقف عرض الفيديوهات المُنشأة تلقائيًا.
قد تعمل ميزة التشغيل الآلي الذكية على تحسين مواد عرض الفيديو على YouTube من خلال تعديل اتجاه الفيديو واقتصاصه بذكاء لتسليط الضوء على اللحظات الرئيسية. إذا كنت تفضّل الاحتفاظ بمواد عرض الفيديو الأصلية، اضبط AssetAutomationSetting
من النوع GENERATE_ENHANCED_YOUTUBE_VIDEOS
على OPTED_OUT
.