W interfejsie Google Ads API niektóre pola wiadomości służą do wskazywania wybranej strategii ustalania stawek w kampanii. Mogą to być:
- Prawdziwie puste wiadomości: na przykład
campaign.manual_cpmnie ma zdefiniowanych pól podrzędnych. - Wiadomości z polami opcjonalnymi: np.
campaign.manual_cpcma opcjonalne pole podrzędneenhanced_cpc_enabled.
Aby zaktualizować pole typu prostego, np. campaign.name, ustaw je bezpośrednio:
campaign.name = "Test campaign value"
Aby zaktualizować zagnieżdżoną wiadomość z polami podrzędnymi, które można ustawić, np. campaign.manual_cpcwłączając ulepszony CPC, ustaw ją w ten sposób:
campaign.manual_cpc.enhanced_cpc_enabled = True
Ustawianie całkowicie pustych wiadomości
Aby użyć strategii ustalania stawek, takiej jak manual_cpm, która jest pustym komunikatem:
- Pobierz pustą instancję typu wiadomości (
ManualCpm). - Użyj znaku
client.copy_from, aby przypisać tę pustą instancję do pola kampanii. - Ręcznie dodaj nazwę pola (
manual_cpm) doupdate_maskwCampaignOperation. Pomocnik maski pola nie może automatycznie wykryć, że pusta wiadomość została ustawiona w sposób jawny.
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 {
# }
Ustawianie wiadomości z opcjonalnymi polami podrzędnymi
Aby używać strategii ustalania stawek manual_cpc bez włączania enhanced_cpc_enabled, możesz zastosować podejście podobne do ManualCpm.
Jednak ponieważ pole ManualCpc ma podpola, dodanie pola manual_cpc do pola update_mask powoduje błąd FieldMaskError.FIELD_HAS_SUBFIELDS. Interfejs API wymaga większej szczegółowości, gdy wiadomość w masce zawiera pola podrzędne.
Aby prawidłowo ustawić wartość campaign.manual_cpc, ale nie ustawiać wartości enhanced_cpc_enabled:
- Utwórz pusty obiekt
ManualCpci przypisz go do zmiennejcampaign.manual_cpc. - Ręcznie dodaj ścieżkę do każdego modyfikowalnego pola podrzędnego elementu
ManualCpcdo elementuupdate_maskw elemencieCampaignOperation. W tym przypadku odpowiednie pole podrzędne toenhanced_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.
Wysyłając żądania za pomocą tych wzorców, możesz zweryfikować ładunek, włączając logowanie i sprawdzając żądanie.