Nell'API Google Ads, alcuni campi dei messaggi vengono utilizzati per indicare una scelta di strategia di offerta per una campagna. Ad esempio:
- Messaggi veramente vuoti: ad esempio,
campaign.manual_cpmnon ha sottocampi definiti. - Messaggi con campi facoltativi: ad esempio,
campaign.manual_cpcha il sottocampo facoltativoenhanced_cpc_enabled.
Per aggiornare un campo primitivo come
campaign.name, impostalo direttamente:
campaign.name = "Test campaign value"
Per aggiornare un messaggio nidificato con campi secondari impostabili, ad esempio campaign.manual_cpc
quando attivi il CPC ottimizzato, impostalo come segue:
campaign.manual_cpc.enhanced_cpc_enabled = True
Impostare messaggi veramente vuoti
Per utilizzare una strategia di offerta come
manual_cpm, che è un messaggio
vuoto:
- Recupera un'istanza vuota del tipo di messaggio
(
ManualCpm). - Utilizza
client.copy_fromper assegnare questa istanza vuota al campo della campagna. - Aggiungi manualmente il nome del campo (
manual_cpm) aupdate_maskinCampaignOperation. L'helper della maschera di campo non può rilevare automaticamente che è stato impostato esplicitamente un messaggio vuoto.
client = GoogleAdsClient.load_from_storage()
# Assume 'campaign' is an existing Campaign object you are updating.
# 1. Get an empty ManualCpm type
empty_cpm = client.get_type('ManualCpm')
# 2. Copy it to the campaign's manual_cpm field
client.copy_from(campaign.manual_cpm, empty_cpm)
# 3. Manually add "manual_cpm" to the update_mask.
from google.api_core.protobuf_helpers import field_mask
campaign_operation = client.get_type('CampaignOperation')
campaign_operation.update = campaign
campaign_operation.update_mask = field_mask(None, campaign)
campaign_operation.update_mask.paths.append("manual_cpm")
# The resulting proto sent to the API will include:
# manual_cpm {
# }
Impostare messaggi con campi secondari facoltativi
Per utilizzare manual_cpc come strategia di offerta senza attivare enhanced_cpc_enabled, puoi provare un approccio simile a ManualCpm.
Tuttavia, poiché ManualCpc ha
sottocampi, l'aggiunta di manual_cpc a
update_mask genera un
errore FieldMaskError.FIELD_HAS_SUBFIELDS. L'API richiede maggiore specificità quando un messaggio nella maschera ha
sottocampi.
Per impostare correttamente campaign.manual_cpc assicurandoti che enhanced_cpc_enabled
rimanga non impostato:
- Crea un oggetto
ManualCpcvuoto e assegnalo acampaign.manual_cpc. - Aggiungi manualmente il percorso a ogni sottocampo modificabile di
ManualCpcaupdate_masksuCampaignOperation. In questo caso, il sottocampo pertinente èenhanced_cpc_enabled.
client = GoogleAdsClient.load_from_storage()
# Assume 'campaign' is an existing Campaign object you are updating.
# 1. Instantiate and assign an empty ManualCpc
campaign.manual_cpc = client.get_type('ManualCpc')
# 2. Manually add the subfield path to the update_mask.
from google.api_core.protobuf_helpers import field_mask
campaign_operation = client.get_type('CampaignOperation')
campaign_operation.update = campaign
campaign_operation.update_mask = field_mask(None, campaign)
# For ManualCpc, because it has subfields, you MUST specify the subfield
# path in the update_mask. This tells the API you are updating something
# within manual_cpc. By not setting enhanced_cpc_enabled on the campaign
# object, it defaults to false.
campaign_operation.update_mask.paths.append("manual_cpc.enhanced_cpc_enabled")
# The update_mask paths will include: ['manual_cpc.enhanced_cpc_enabled']
# This correctly signals to the API that ManualCpc is the chosen strategy,
# with enhanced_cpc_enabled in its default state.
Quando invii richieste utilizzando questi pattern, puoi verificare il payload attivando la registrazione e ispezionando la richiesta.