Поиск и усиление; Поисковый поток

Видео: Отчетность

API Google Рекламы имеет унифицированный механизм получения атрибутов и создания отчетов по показателям , который позволяет создавать запросы с использованием языка запросов Google Рекламы . Это позволяет выполнять сложные запросы, которые могут возвращать большие объемы данных об отдельных аккаунтах Google Рекламы.

Вы можете создавать запросы, используя методы Search или SearchStream . Оба метода поддерживают одни и те же запросы и возвращают эквивалентные результаты. Метод Search возвращает данные в настраиваемых размерах страниц, что позволяет перебирать набор результатов с помощью разбиения на страницы. Это может быть выгодно в условиях низкой пропускной способности или ненадежной сети, например, для разделения большого набора результатов на более мелкие ответы, которые можно будет повторно получить в случае потери соединения. С другой стороны, метод SearchStream передает весь набор результатов обратно в один ответ, что может быть более эффективно для массового извлечения данных.

И Search , и SearchStream используют один и тот же базовый URL-адрес:

    https://googleads.googleapis.com/v16/customers/CUSTOMER_ID/googleAds

Метод поиска на основе страниц принимает необязательный параметр pageSize , который ограничивает количество результатов, возвращаемых в одном ответе API.

POST /v16/customers/CUSTOMER_ID/googleAds:search HTTP/1.1
Host: googleads.googleapis.com
Content-Type: application/json
Authorization: Bearer ACCESS_TOKEN
developer-token: DEVELOPER_TOKEN

{
"pageSize": 10000,
"query": "SELECT ad_group_criterion.keyword.text, ad_group_criterion.status FROM ad_group_criterion WHERE ad_group_criterion.type = 'KEYWORD' AND ad_group_criterion.status = 'ENABLED'"
}

Если в результатах больше строк, чем pageSize , в ответе возвращается nextPageToken :

{
  "results": [
    // ...
    // ...
    // ...
  ],
  "nextPageToken": "CPii5aS87vfFTBAKGJvk36qpLiIWUW5SZk8xa1JPaXJVdXdIR05JUUpxZyoCVjMwADjUBkD___________8B",
  "fieldMask": "adGroupCriterion.keyword.text,adGroupCriterion.status"
}

Повторение того же запроса с добавленным pageToken со значением выше приводит к получению следующей страницы результатов:

POST /v16/customers/CUSTOMER_ID/googleAds:search HTTP/1.1
Host: googleads.googleapis.com
Content-Type: application/json
Authorization: Bearer ACCESS_TOKEN
developer-token: DEVELOPER_TOKEN

{
"pageSize": 10000,
"query": "SELECT ad_group_criterion.keyword.text, ad_group_criterion.status FROM ad_group_criterion WHERE ad_group_criterion.type = 'KEYWORD' AND ad_group_criterion.status = 'ENABLED'",
"pageToken": "CPii5aS87vfFTBAKGJvk36qpLiIWUW5SZk8xa1JPaXJVdXdIR05JUUpxZyoCVjMwADjUBkD___________8B"
}

Чтобы использовать метод SearchStream , который возвращает все результаты в одном потоковом ответе, просто измените метод службы в URL-адресе на searchStream ( pageSize и pageToken не требуются для SearchStream ):

POST /v16/customers/CUSTOMER_ID/googleAds:searchStream HTTP/1.1
Host: googleads.googleapis.com
Content-Type: application/json
Authorization: Bearer ACCESS_TOKEN
developer-token: DEVELOPER_TOKEN

{
    "query": "SELECT ad_group_criterion.keyword.text, ad_group_criterion.status FROM ad_group_criterion WHERE ad_group_criterion.type = 'KEYWORD' AND ad_group_criterion.status = 'ENABLED'"
}