A veiculação de anúncios da Geração de demanda é controlada usando a segmentação atribuída ao parceiro principal, ao anunciante, ao item de linha e aos grupos de anúncios.
Use a segmentação atribuída a um item de linha e a um grupo de anúncios da Geração de demanda para alcançar os clientes ideais e melhorar a performance da campanha.
Decidir onde atribuir a segmentação
A segmentação pode ser atribuída a itens de linha e grupos de anúncios da Geração de demanda.
Atribua a segmentação a um item de linha da Geração de demanda se quiser que ela seja aplicada a todos os anúncios veiculados nesse item de linha. Caso contrário, atribua a segmentação a grupos de anúncios individuais.
Suporte de segmentação por tipo de recurso da Geração de demanda
Cada tipo de recurso oferece suporte a determinados tipos de segmentação.
Confira a lista de tipos de segmentação com suporte para itens de linha da Geração de demanda:
TARGETING_TYPE_CARRIER_AND_ISPTARGETING_TYPE_DAY_AND_TIMETARGETING_TYPE_DEVICE_MAKE_MODELTARGETING_TYPE_DEVICE_TYPETARGETING_TYPE_GEO_REGIONTARGETING_TYPE_KEYWORDTARGETING_TYPE_LANGUAGETARGETING_TYPE_NEGATIVE_KEYWORD_LISTTARGETING_TYPE_OPERATING_SYSTEMTARGETING_TYPE_POI
Confira a lista de tipos de segmentação com suporte para grupos de anúncios da Geração de demanda:
TARGETING_TYPE_AGE_RANGETARGETING_TYPE_APPTARGETING_TYPE_APP_CATEGORYTARGETING_TYPE_AUDIENCE_GROUPTARGETING_TYPE_CATEGORYTARGETING_TYPE_GENDERTARGETING_TYPE_GEO_REGIONTARGETING_TYPE_HOUSEHOLD_INCOMETARGETING_TYPE_KEYWORDTARGETING_TYPE_LANGUAGETARGETING_TYPE_PARENTAL_STATUSTARGETING_TYPE_URLTARGETING_TYPE_YOUTUBE_CHANNELTARGETING_TYPE_YOUTUBE_VIDEO
O suporte de TARGETING_TYPE_GEO_REGION, TARGETING_TYPE_POI e
TARGETING_TYPE_LANGUAGE depende da configuração do campo
demandGenSettings.geoLanguageTargetingEnabled
no recurso LineItem principal. Se o campo for verdadeiro, a segmentação por local e idioma só poderá ser atribuída ao item de linha principal. Se o campo for falso, essa segmentação só poderá ser atribuída a grupos de anúncios individuais.
Encontrar opções de segmentação disponíveis
A segmentação é identificada com base no tipo. Identifique as opções de segmentação de uma das seguintes maneiras:
- Use um valor de enumeração relevante, como com os tipos de enumeração
AgeRangeouExchange. - Recupere entidades segmentáveis, como canais ou listas de locais, usando o serviço relacionado.
- Recupere IDs de opções de segmentação para um tipo de segmentação usando
listesearchmétodos.
Recuperar a segmentação atual
A segmentação atual restringe o que pode ser adicionado a um item de linha ou grupo de anúncios.
Os itens de linha e grupos de anúncios da Geração de demanda só mostram a segmentação TARGETING_TYPE_KEYWORD herdada. Isso significa que você precisa recuperar a segmentação do anunciante, do item de linha e do grupo de anúncios para ter uma contabilidade completa de toda a segmentação que afeta a veiculação de anúncios.
Recupere a segmentação atual em todos os tipos de segmentação usando solicitações de lista em massa.
Recuperar a segmentação atual do parceiro e do anunciante
Saiba como acessar a segmentação atual de um anunciante, incluindo a segmentação de parceiros herdada:
Python
# Provide the ID of the advertiser. advertiser_id = advertiser-id # Create the page token variable. next_page_token = "" while True: # Execute the list request. response = ( service.advertisers() .listAssignedTargetingOptions( advertiserId=advertiser_id, pageToken=next_page_token, ) .execute() ) # If response is not empty, display the retrieved assigned targeting # options. if response: for assigned_targeting_option in response.get( "assignedTargetingOptions", [] ): ato_name = assigned_targeting_option.get( "name", None ) if ato_name: print(f"Assigned Targeting Option {ato_name}.") else: print(f"No targeting is currently assigned to {advertiser_id}.") sys.exit(1) # Update the next page token. # Break out of loop if there is no next page. if "nextPageToken" in response: next_page_token = response["nextPageToken"] else: break
Recuperar a segmentação atual do item de linha
Saiba como acessar a segmentação atual atribuída diretamente a um item de linha:
Python
# Provide the ID of the parent advertiser. advertiser_id = advertiser-id # Provide the ID of the Demand Gen line item. line_item_id = line-item-id # Create the page token variable. next_page_token = "" while True: # Execute the list request. response = ( service.advertisers() .lineItems() .bulkListAssignedTargetingOptions( advertiserId=advertiser_id, lineItemIds=[line_item_id], pageToken=next_page_token, ) .execute() ) # If response is not empty, display the retrieved assigned targeting # options line items. if response: for assigned_option in response.get( "lineItemAssignedTargetingOptions", [] ): ato_name = assigned_option.get("assignedTargetingOption", {}).get( "name", None ) if ato_name: print(f"Assigned Targeting Option {ato_name} found.") else: print(f"No targeting is currently assigned to {line_item_id}.") sys.exit(1) # Update the next page token. # Break out of loop if there is no next page. if "nextPageToken" in response: next_page_token = response["nextPageToken"] else: break
Recuperar a segmentação atual do grupo de anúncios
Saiba como acessar a segmentação atual atribuída diretamente a um grupo de anúncios:
Python
# Provide the ID of the parent advertiser. advertiser_id = advertiser-id # Provide the ID of the ad group. ad_group_id = ad-group-id # Create the page token variable. next_page_token = "" while True: # Execute the list request. response = ( service.advertisers() .adGroups() .bulkListAssignedTargetingOptions( advertiserId=advertiser_id, adGroupIds=[ad_group_id], pageToken=next_page_token, ) .execute() ) # If response is not empty, display the retrieved assigned targeting # options line items. if response: for assigned_option in response.get( "adGroupAssignedTargetingOptions", [] ): ato_name = assigned_option.get("assignedTargetingOption", {}).get( "name", None ) if ato_name: print(f"Assigned Targeting Option {ato_name} found.") else: print(f"No targeting is currently assigned to {ad_group_id}.") sys.exit(1) # Update the next page token. # Break out of loop if there is no next page. if "nextPageToken" in response: next_page_token = response["nextPageToken"] else: break
Atribuir segmentação a recursos
Você precisa fazer solicitações separadas para atualizar a segmentação do item de linha e do grupo de anúncios.
Atribuir segmentação do item de linha
Saiba como adicionar a seguinte lógica de segmentação a um item de linha:
- Somente anúncios veiculados em computadores.
Não faça lances em inventários veiculados ao lado de conteúdo que corresponda à palavra-chave "sorvete".
Python
# Provide the ID of the parent advertiser. advertiser_id = advertiser-id # Provide the ID of the line item. line_item_id = line-item-id # Build the "ice cream" negative keyword assigned targeting option. keyword_assigned_targeting_option = { "keywordDetails": {"keyword": "ice cream", "negative": True} } # Build the delete request for device type targeting to remove all device # types to only target computers. device_type_delete_request = { "targetingType": "TARGETING_TYPE_DEVICE_TYPE", "assignedTargetingOptionIds": [ "DEVICE_TYPE_SMART_PHONE", "DEVICE_TYPE_CONNECTED_TV", "DEVICE_TYPE_TABLET" ], } # Create a bulk edit request. bulk_edit_targeting_request = { "lineItemIds": [line_item_id], "createRequests": [ { "targetingType": "TARGETING_TYPE_KEYWORD", "assignedTargetingOptions": [ keyword_assigned_targeting_option ], } ], "deleteRequests": [ device_type_delete_request ] } # Build and execute request. response = ( service.advertisers() .lineItems() .bulkEditAssignedTargetingOptions( advertiserId=advertiser_id, body=bulk_edit_targeting_request ) .execute() ) # Print the request results. if ( "updatedLineItemIds" in response and len(response["updatedLineItemIds"]) != 0 ): print( f'Targeting configurations for {response["updatedLineItemIds"][0]} ' "were successfully updated." ) elif ( "failedLineItemIds" in response and len(response["failedLineItemIds"]) != 0 ): print( f'Targeting configurations for {response["failedLineItemIds"][0]} ' "failed to update." ) if "errors" in response and len(response["errors"]) != 0: print("The failed updates were caused by the following errors:") for error in response["errors"]: print(f'Code {error["code"]}: {error["message"]}') else: print("No successful or failed updates were reported.")
Atribuir segmentação do grupo de anúncios
Saiba como adicionar a seguinte lógica de segmentação a um grupo de anúncios:
- Veicular apenas para pais.
Não veicular no canal do YouTube fornecido.
Python
# Provide the ID of the parent advertiser. advertiser_id = advertiser-id # Provide the ID of the ad group. ad_group_id = ad-group-id # Provide the YouTube channel ID to negatively target. yt_channel_id = youtube-channel-id # Build the assigned targeting option to negatively target the given YouTube # channel. youtube_channel_assigned_targeting_options = [ { "youtubeChannelDetails": { "channelId": yt_channel_id, "negative": True } }, ] # Build the assigned targeting options to target only parents. parental_status_assigned_targeting_options = [ { "parentalStatusDetails": { "parentalStatus": "PARENTAL_STATUS_PARENT" } }, ] # Create a bulk edit request. bulk_edit_targeting_request = { "adGroupIds": [ad_group_id], "createRequests": [ { "targetingType": "TARGETING_TYPE_YOUTUBE_CHANNEL", "assignedTargetingOptions": ( youtube_channel_assigned_targeting_options ) }, { "targetingType": "TARGETING_TYPE_PARENTAL_STATUS", "assignedTargetingOptions": ( parental_status_assigned_targeting_options ), } ] } # Build and execute request. response = ( service.advertisers() .adGroups() .bulkEditAssignedTargetingOptions( advertiserId=advertiser_id, body=bulk_edit_targeting_request ) .execute() ) # Print the request results. if ( "updatedAdGroupIds" in response and len(response["updatedAdGroupIds"]) != 0 ): print( f'Targeting configurations for {response["updatedAdGroupIds"][0]} ' "were successfully updated." ) elif ( "failedAdGroupIds" in response and len(response["failedAdGroupIds"]) != 0 ): print( f'Targeting configurations for {response["failedAdGroupIds"][0]} ' "failed to update." ) if "errors" in response and len(response["errors"]) != 0: print("The failed updates were caused by the following errors:") for error in response["errors"]: print(f'Code {error["code"]}: {error["message"]}') else: print("No successful or failed updates were reported.")