Exemplos de scripts para grupos de produtos
As secções seguintes mostram exemplos de scripts que obtêm grupos de produtos e atualizam os respetivos montantes de oferta.
Obter grupos de produtos
Para obter todos os grupos de produtos numa conta, utilize o método AdsApp.productGroups( ).
function main() {
var productGroups = AdsApp.productGroups().get();
while (productGroups.hasNext()) {
var productGroup = productGroups.next();
switch (productGroup.getDimension()) {
case "ROOT": {
break;
}
case "CATEGORY": {
var category = productGroup.getValue();
break;
}
case "CHANNEL": {
var channel = productGroup.getValue();
break;
}
case "CHANNEL_EXCLUSIVITY": {
var channelExclusivity = productGroup.getValue();
break;
}
case "BRAND": {
var brand = productGroup.getValue();
break;
}
case "CONDITION": {
var condition = productGroup.getValue();
break;
}
case "CUSTOM_LABEL": {
// It's only necessary to cast the product group to a CustomLabel product
// group if you need to get the label's name (i.e., CustomLabel0).
var customLabel = productGroup.asCustomLabel();
var labelType = customLabel.getType();
var labelValue = customLabel.getValue();
break;
}
case "ITEM_ID": {
var id = productGroup.getValue();
break;
}
case "PRODUCT_TYPE": {
// It's only necessary to cast the product group to a ProductType product
// group if you need to get the type's name (i.e., PRODUCT_TYPE_1).
var productType = productGroup.asProductType();
var typeName = productType.getType();
var typeValue = productType.getValue());
break;
}
}
}
}
Outra opção é obter grupos de produtos através de campanhas de compras ou grupos de anúncios de compras. Para obter grupos de produtos por grupos de anúncios, chame primeiro o método AdsApp.shoppingAdGroups() e, em seguida, chame o método AdGroup.productGroups( ). Para campanhas, também chamaria os métodos AdsApp.shoppingCampaigns() e Campaign.productGroups( ).
function main() {
var shoppingAdGroups = AdsApp.shoppingAdGroups()
.get();
while (shoppingAdGroups.hasNext()) {
var adGroup = shoppingAdGroups.next();
var productGroups = adGroup.productGroups().get();
while (productGroups.hasNext()) {
var productGroup = productGroups.next();
switch (productGroup.getDimension()) {
case "ROOT": {
break;
}
case "CATEGORY": {
var category = productGroup.getValue();
break;
}
case "CHANNEL": {
var channel = productGroup.getValue();
break;
}
case "CHANNEL_EXCLUSIVITY": {
var channelExclusivity = productGroup.getValue();
break;
}
case "BRAND": {
var brand = productGroup.getValue();
break;
}
case "CONDITION": {
var condition = productGroup.getValue();
break;
}
case "CUSTOM_LABEL": {
// It's only necessary to cast the product group to a CustomLabel product
// group if you need to get the label's name (i.e., CustomLabel0).
var customLabel = productGroup.asCustomLabel();
var labelType = customLabel.getType();
var labelValue = customLabel.getValue();
break;
}
case "ITEM_ID": {
var id = productGroup.getValue();
break;
}
case "PRODUCT_TYPE": {
// It's only necessary to cast the product group to a ProductType product
// group if you need to get the type's name (i.e., PRODUCT_TYPE_1).
var productType = productGroup.asProductType();
var typeName = productType.getType();
var typeValue = productType.getValue());
break;
}
}
}
}
}
A aplicar condições
Para filtrar a lista de grupos de produtos, utilize o método withCondition . Ao utilizar withCondition
o , pode filtrar grupos de produtos pelos valores de métrica padrão, como cliques e conversões, mas também pode filtrar por quantidade de oferta e grupo de produtos.
O exemplo seguinte mostra como obter o grupo de produtos Skis se o caminho for "Todos os produtos > Sporting Goods > Winter Sports > Skis >> Recondicionados > Cross-Country Skis".
function main() {
var shoppingAdGroup = AdsApp.shoppingAdGroups().withIds(["123456789"]).get().next();
var productGroups = shoppingAdGroup.productGroups()
.withCondition("ProductGroup = skis")
.get();
while (productGroups.hasNext()) {
var group = productGroups.next();
}
}
Uma vez que Skis é subdividido pela condição Recondicionada, a resposta inclui o grupo de produtos Skis selecionado e o grupo de produtos OtherCase para Recondicionado.
dimension CATEGORY
value Skis
cpc null
parent 4578503857653096
dimension CONDITION
value OtherCase
cpc 1
parent 4578503857653099
Atualizar a oferta de um grupo de produtos
Normalmente, quer aumentar as ofertas quando o desempenho é mau e diminuir as ofertas quando o desempenho é bom. Este exemplo mostra como obter grupos de produtos com um desempenho fraco e aumentar o montante da oferta. (Este exemplo utiliza cliques e taxas de conversão para determinar grupos com mau desempenho, mas deve utilizar as métricas e limiares adequados para si.)
function main() {
var shoppingAdGroup = AdsApp.shoppingAdGroups().withIds(["123456789"]).get().next();
var productGroups = shoppingAdGroup.productGroups()
.withCondition("Clicks < 30")
.withCondition("ClickConversionRate < .25")
.forDateRange("LAST_MONTH")
.get();
var groupsToUpdate = [];
while (productGroups.hasNext()) {
groupsToUpdate.push(productGroups.next());
}
for (var group of groupsToUpdate) {
group.setMaxCpc(.35);
}
}