Дополнительные компоненты Performance Max

Цели конверсии

При создании кампании Performance Max автоматически создается ряд целей конверсии , соответствующих целям CustomerConversionGoal в учетной записи. Вы можете настроить эти цели для каждой из ваших кампаний Performance Max, обновив их.

Для этого вам сначала нужно получить идентификатор кампании (кампаний) Performance Max и список всех целей конверсии клиентов. Вот пример изменения целей одной кампании, хотя вы также можете настроить свой код для перебора нескольких кампаний Performance Max.

// Query for a campaign by name. Update this logic to pull the campaigns you'd
// like to edit
const campaignName = "My PMax campaign";
let campaignId = "";

const search = AdsApp.search(`SELECT campaign.id FROM campaign WHERE campaign.name = "${campaignName}"`);
if (search.hasNext()) {
  campaignId = search.next().campaign.id;
  console.log(`Updating conversion goals for ${campaignName}: ${campaignId}`);
}
else
{
  console.log(`No campaign named "${campaignName}" found`);
  // Perform further error handling here
}

// Query for a list of customer conversion goals
const searchResults = AdsApp.search(
  `SELECT
     customer_conversion_goal.category,
     customer_conversion_goal.origin
   FROM customer_conversion_goal`
);

Затем вы можете пройтись по всем полученным целям конверсии и создать операцию обновления для текущей кампании Performance Max, чтобы настроить таргетинг для каждой цели. Пример кода, показанный далее в этом разделе, устанавливает для всех целей возможность назначения ставок, но вам потребуется настроить эту часть логики в соответствии с тем, чего вы хотите добиться от своей кампании.

Мы рекомендуем настраивать цели конверсии в отдельной транзакции, отличной от остального процесса создания кампании. Для CampaignConversionGoalOperation необходимо установить параметр partialFailure для запроса в значение false . Если вы хотите выполнить этот код в той же транзакции, где вы впервые создаете кампанию, необходимо отключить частичную ошибку для всех операций. В этом примере кода показано, как выполнить эту операцию в отдельной транзакции.

operations = [];
while (searchResults.hasNext()) {
  const row = searchResults.next();
  const conversionGoal = row.customerConversionGoal;

  operations.push({
    "campaignConversionGoalOperation": {
      "update": {
        "resourceName": `customers/${customerId}/campaignConversionGoals/${campaignId}~${conversionGoal.category}~${conversionGoal.origin}`,
        // Insert your logic here to determine whether you want this particular
        // campaign conversion goal to be biddable or not.
        // This code will just default everything to being biddable, but that
        // is not necessarily best for your use case.
        "biddable": true
      },
      "updateMask": "biddable"
    }
  });
}

AdsApp.mutateAll(operations, {partialFailure: false});

Таргетинг кампании

Для настройки таргетинга кампаний в Performance Max обязательно ознакомьтесь с руководством по API , где представлен полный список допустимых типов критериев.

Дополнительные критерии для создания кампании Performance Max не являются обязательными, но могут быть полезны для ограничения таргетинга в зависимости от ваших задач. В следующем примере кода показано, как настроить таргетинг по географическому местоположению. Формат для других типов критериев можно найти в документации CampaignCriterion .

Вы можете создать эти критерии вместе с самой кампанией в рамках одного вызова функции mutateAll . В этом примере кода предполагается, что именно так вы структурируете свой код.

operations.push({
  "campaignCriterionOperation": {
    "create": {
      "campaign": campaignOperation.campaignOperation.create.resourceName,
      "negative": false,
      "location": {
        // 1023191 represents New York City
        "geoTargetConstant": "geoTargetConstants/1023191"
      }
    }
  }
});

Сигналы групп активов

Перед началом работы ознакомьтесь с информацией о сигналах групп ресурсов в документации API. Они настраиваются путем привязки группы ресурсов к существующему критерию AudienceInfo или SearchThemeInfo . Если вы хотите использовать аудиторию, укажите поле audience вместо поля searchTheme с именем ресурса аудитории.

operations.push({
  "assetGroupSignalOperation": {
    "create": {
      "assetGroup": assetGroupOperation.assetGroupOperation.create.resourceName,
      "searchTheme": {
        "text": "mars cruise"
      }
    }
  }
});