Di Google Ads API, beberapa kolom pesan digunakan untuk menunjukkan pilihan strategi bidding untuk Kampanye. Di antaranya yaitu:
- Pesan yang benar-benar kosong: Misalnya,
campaign.manual_cpmtidak memiliki sub-bidang yang ditentukan. - Pesan dengan kolom opsional: Misalnya,
campaign.manual_cpcmemiliki sub-kolom opsionalenhanced_cpc_enabled.
Untuk memperbarui kolom primitif seperti
campaign.name, Anda dapat menyetelnya secara langsung:
campaign.name = "Test campaign value"
Untuk mengupdate pesan bertingkat dengan sub-bidang yang dapat disetel, seperti campaign.manual_cpc
saat mengaktifkan Enhanced CPC, tetapkan seperti berikut:
campaign.manual_cpc.enhanced_cpc_enabled = True
Menetapkan pesan yang benar-benar kosong
Untuk menggunakan strategi bidding seperti
manual_cpm, yang merupakan pesan
kosong:
- Dapatkan instance kosong dari jenis pesan
(
ManualCpm). - Gunakan
client.copy_fromuntuk menetapkan instance kosong ini ke kolom kampanye. - Tambahkan nama kolom (
manual_cpm) secara manual keupdate_maskdiCampaignOperation. Helper mask kolom tidak dapat mendeteksi secara otomatis bahwa pesan kosong telah ditetapkan secara eksplisit.
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 {
# }
Menetapkan pesan dengan sub-bidang opsional
Untuk menggunakan manual_cpc sebagai strategi bidding tanpa mengaktifkan enhanced_cpc_enabled, Anda dapat mencoba pendekatan yang mirip dengan ManualCpm.
Namun, karena ManualCpc memiliki
sub-bidang, menambahkan manual_cpc ke
update_mask akan menghasilkan
error FieldMaskError.FIELD_HAS_SUBFIELDS. API memerlukan spesifisitas yang lebih tinggi saat pesan dalam mask memiliki sub-bidang.
Untuk menyetel campaign.manual_cpc dengan benar sekaligus memastikan enhanced_cpc_enabled
tetap tidak disetel:
- Buat instance objek
ManualCpckosong dan tetapkan kecampaign.manual_cpc. - Tambahkan jalur ke setiap sub-kolom yang dapat diubah dari
ManualCpcsecara manual keupdate_maskdiCampaignOperation. Dalam hal ini, sub-bidang yang relevan adalahenhanced_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.
Saat mengirim permintaan menggunakan pola ini, Anda dapat memverifikasi payload dengan mengaktifkan logging dan memeriksa permintaan.