Skrip Google Ads mendukung draf dan eksperimen kampanye, yang digunakan untuk menyiapkan dan menguji perubahan pada kampanye Jaringan Penelusuran dan Jaringan Display.
Draf adalah clone kampanye yang ada yang tidak akan menayangkan iklannya sendiri, tetapi dapat digunakan untuk mengatur perubahan tanpa mengubah kampanye asli. Perubahan yang dipentaskan kemudian dapat diterapkan ke kampanye dasar.
Eksperimen menjalankan kampanye yang dapat disesuaikan secara paralel dengan kampanye asli, dan menampilkan iklan ke persentase traffic yang ditentukan. Berdasarkan hasil eksperimen, Anda dapat menerapkan perubahan ke kampanye asli, membuat cabang eksperimen ke kampanye independen, atau membatalkan kampanye eksperimen.
Panduan ini menjelaskan alur kerja dasar untuk menggunakan draf dan eksperimen dalam skrip.
Draf
Buat draf
Draf dibuat dari kampanye dasar yang ada menggunakan
DraftBuilder
dan memberikan nama yang unik. Kampanye dasar harus berupa kampanye Penelusuran, kampanye Jaringan Penelusuran dengan Perluasan Display, atau kampanye Display (tidak termasuk kampanye Aplikasi Seluler untuk Jaringan Display), dan tidak boleh memiliki anggaran bersama.
const campaign = AdsApp.campaigns()
.withCondition(`campaign.name = "${campaignName}"`)
.get()
.next();
const draftBuilder = campaign.newDraftBuilder()
.withName("INSERT_DRAFT_NAME_HERE")
.build();
const draft = draftBuilder.getResult();
DraftBuilder.build()
menampilkan
DraftOperation
,
operasi umum dalam skrip. Lihat panduan untuk pembuat kami untuk mengetahui detail selengkapnya.
draft
diidentifikasi secara unik oleh kombinasi ID kampanye dasarnya dan ID draf. Lihat
DraftSelector.withIds()
untuk mengetahui informasi selengkapnya.
Menyediakan draf kampanye
Objek draft
menghubungkan kampanye dasar dan kampanye draf. Untuk melakukan penyesuaian pada kampanye dasar, Anda menyebarkan perubahan melalui draf kampanye.
Kampanye draf, seperti kampanye lainnya, memiliki metode untuk mendapatkan dan menetapkan berbagai atributnya seperti kriteria, grup iklan, bid, dan iklan.
const draftCampaign = draft.getDraftCampaign();
draftCampaign.setAdRotationType("CONVERSION_OPTIMIZE");
draftCampaign.createNegativeKeyword("shoes");
Pemeriksaan kebijakan iklan dilakukan untuk kampanye draf seperti halnya untuk kampanye dasar. Anda tidak akan dapat menjalankan eksperimen dari kampanye draf yang memiliki iklan yang melanggar kebijakan.
Menjalankan draf
Setelah menyediakan kampanye draf, Anda dapat melakukan salah satu hal berikut:
Jika tidak ingin menggunakan perubahan, Anda cukup menghapus draf. Penghapusan draf tidak dapat dibatalkan, tetapi draf tersebut masih dapat dilihat di bagian Semua draf di tab draf pada UI Google Ads.
draft.remove();
Jika Anda memutuskan untuk menyimpan perubahan yang Anda buat dalam draf, Anda dapat melanjutkan dan menerapkannya:
draft.startApplying();
Metode ini memulai proses penerapan pembaruan ke kampanye dasar, sehingga draf akan memiliki status Menerapkan... di UI Google Ads. Namun, metode ini tidak akan memberi tahu Anda saat proses selesai.
Jika ingin menguji perubahan terlebih dahulu, Anda dapat menggunakan draf untuk membuat eksperimen.
Eksperimen
Membuat eksperimen
experiment
serupa dengan draf, dan juga dibuat dari kampanye dasar. Anda membuat experiment
dengan
ExperimentBuilder
.
Hal ini akan otomatis membuat eksperimen dengan dua "cabang" yang merepresentasikan
berbagai bagian eksperimen. Satu grup (disebut grup kontrol) akan berisi kampanye dasar, dan grup lainnya (disebut grup perlakuan) akan berisi draf kampanye baru yang akan Anda sesuaikan (sesuai langkah-langkah untuk draf yang ditampilkan sebelumnya) sebelum menjadwalkan eksperimen.
Saat membuat eksperimen, pastikan untuk menyetel semua hal berikut di pembuat:
withCampaign
- Kampanye yang ingin Anda jadikan dasar eksperimen.
withTrafficSplitPercent
- Berapa banyak traffic yang akan masuk ke grup eksperimen. Untuk 50%, tentukan
50
. withStartDate
danwithEndDate
- Menentukan tanggal mulai dan akhir kampanye. Tentukan dalam format
YYYYMMdd
.
withType
SEARCH_CUSTOM
atauDISPLAY_CUSTOM
, bergantung pada jaringan yang Anda gunakan.withSuffix
- Menentukan akhiran yang akan ditambahkan ke nama kampanye perlakuan saat dibuat.
withGoals
- Menentukan sasaran untuk eksperimen ini. Ini hanyalah pengingat bagi diri Anda sendiri
tentang tujuan Anda saat membuatnya. Nilai default yang baik adalah
[{metric: 'CLICKS', direction: 'INCREASE'}]
.
Persentase pemisahan traffic menentukan bagian traffic yang akan menampilkan iklan dari kampanye eksperimen, bukan kampanye dasar. Oleh karena itu, setiap kampanye dasar hanya dapat memiliki satu eksperimen yang berjalan dalam satu waktu.
const experiment = AdsApp.newExperimentBuilder()
.withCampaign(campaign)
.withTrafficSplitPercent(50)
.withStartDate("20230501")
.withEndDate("20230601")
.withType("SEARCH_CUSTOM")
.withSuffix("experiment")
.withGoals([{metric: 'CLICKS', direction: 'INCREASE'}])
.build();
// The experimentCampaign represents the customizeable draft.
const experimentCampaign = experiment.getExperimentCampaign();
Tidak seperti draf, eksperimen diidentifikasi secara unik oleh satu ID. Lihat ExperimentSelector.withIds()
untuk mengetahui informasi selengkapnya.
Menyediakan kampanye eksperimen
Mirip dengan draft
, experiment
itu sendiri bukanlah kampanye. Sebaliknya, atribut ini
menghubungkan kampanye dasar, draf, dan kampanye eksperimen. Kolom kampanye eksperimen dapat diubah, dengan pengecualian berikut:
- nama
- status
- tanggal mulai
- tanggal akhir
- anggaran
const experimentCampaign = experiment.getExperimentCampaign();
// Will succeed.
experimentCampaign.setAdRotationType("ROTATE_FOREVER");
experimentCampaign.createNegativeKeyword("sneakers");
// Will fail.
experimentCampaign.setName("INSERT_EXPERIMENT_NAME_HERE");
Perubahan pada nama, tanggal mulai, dan tanggal akhir dapat dilakukan pada eksperimen, setelah itu perubahan akan diterapkan ke kampanye eksperimen.
// Will succeed.
experiment.setName("INSERT_EXPERIMENT_NAME_HERE");
// Will succeed if date is acceptable.
const date = "20220601";
experiment.setStartDate(date);
Untuk memulai eksperimen, panggil experiment.startScheduling()
. Proses ini bersifat asinkron karena harus menyalin semua setelan dari kampanye dasar.
Setelah eksperimen berakhir
Setelah eksperimen selesai, Anda memiliki beberapa opsi. Sebaiknya biarkan eksperimen selesai sepenuhnya sehingga iklan tidak akan ditayangkan lagi, tetapi Anda masih dapat berinteraksi dengannya. Eksperimen yang Selesai masih dapat dihapus, diterapkan, atau ditingkatkan, dan statistik performa kampanyenya masih dapat diakses.
experiment.finish();
const stats = experimentCampaign.getStatsFor("INSERT_TIME_PERIOD_HERE");
Jika tidak puas dengan eksperimen berdasarkan statistik, Anda dapat menghapus eksperimen, yang juga menghapus kampanye eksperimen. Penghapusan eksperimen tidak dapat dibatalkan, tetapi eksperimen tersebut masih dapat dilihat di bagian Semua eksperimen di tab eksperimen pada UI Google Ads.
experiment.remove();
Jika Anda puas dengan hasil eksperimen, Anda memiliki dua opsi:
Anda dapat mulai menerapkan perubahan dan seperti halnya draf, Anda tidak akan diberi tahu saat proses selesai.
experiment.startApplying();
Anda dapat menetapkan kampanye eksperimen sebagai kampanye independen yang beroperasi penuh, tanpa memengaruhi kampanye dasar. Proses ini, yang dikenal sebagai kelulusan, selesai dengan segera dan memerlukan penetapan anggaran baru.
const budget = AdsApp.budgets() .withCondition(`campaign_budget.id = ${budgetId}`) .get() .next(); experiment.graduate(budget);
Kampanye baru tidak dapat lagi berbagi anggaran dengan kampanye dasar, yang memerlukan anggaran baru. Kampanye yang telah diupgrade sama seperti kampanye normal karena semua kolomnya dapat diubah dan dapat berfungsi sebagai kampanye dasar untuk draf dan eksperimen lainnya.
Pertimbangan lainnya
Entitas dasar
Pengenalan draf dan eksperimen ke skrip Google Ads juga memperkenalkan
konsep entitas dasar. Kampanye draf dan eksperimen serta grup iklan di dalamnya berbeda dari kampanye dasar aslinya, itulah sebabnya Campaign
dan AdGroup
kini memiliki metode untuk mengakses kampanye dasar dan grup iklannya: getBaseCampaign()
dan getBaseAdGroup()
.
Metode ini menampilkan entity yang memanggil jika dipanggil oleh kampanye atau grup iklan dasar. Entitas dalam kampanye dan grup iklan, seperti kata kunci dan iklan, juga telah diberi metode tersebut.
Untuk membantu melacak entity dasar, kampanye telah diberi metode
isBaseCampaign()
,
isDraftCampaign()
,
dan
isExperimentCampaign()
.
Metode
Campaign.draftCampaigns()
dan
Campaign.experimentCampaigns()
baru memungkinkan Anda mengakses semua kampanye draf dan eksperimen yang memiliki
kampanye panggilan sebagai kampanye dasarnya. Namun, Anda tidak dapat memilih kampanye draf dengan
CampaignSelector.withCondition()
;
gunakan
AdsApp.drafts()
sebagai gantinya.
Penanganan error
Metode berikut yang melibatkan draf dan eksperimen akan dilanjutkan saat skrip dijalankan, tetapi mungkin gagal secara asinkron:
Draft.startApplying()
Experiment.startApplying()
Experiment.startScheduling()
Anda harus menunggu untuk memeriksa apakah operasi ini berhasil. UI Google Ads
menampilkan status Diterapkan atau Aktif setelah penyelesaian yang berhasil
dari startApplying()
dan startScheduling()
. Selain itu, pesan ini menunjukkan
Tidak dapat diterapkan atau Tidak dapat dibuat jika gagal, sehingga Anda dapat mengklik untuk
melihat error.
Mungkin juga beberapa metode gagal di tahap pratinjau, tetapi berhasil setelah dijalankan; misalnya, setelah membuat draf:
const draftCampaign = draft.getDraftCampaign();
draftCampaign.createNegativeKeyword("shoes"); // Will fail in preview.
Tindakan ini akan gagal dalam mode pratinjau karena tidak dapat mengakses kampanye draf secara langsung.
Demikian pula, membuat eksperimen dan langsung mencoba mengambil kampanye drafnya akan gagal dalam mode pratinjau, karena drafnya sebenarnya tidak dibuat.
Oleh karena itu, periksa log di bawah daftar skrip Anda setelah menjalankannya, dan lanjutkan dengan skrip yang gagal dalam pratinjau hanya jika Anda yakin penyebabnya adalah karena batasan dalam mode pratinjau.