API Google Рекламы имеет унифицированный механизм получения атрибутов и создания отчетов по показателям , который позволяет создавать запросы с использованием языка запросов Google Рекламы . Это позволяет выполнять сложные запросы, которые могут возвращать большие объемы данных об отдельных аккаунтах Google Рекламы.
Вы можете создавать запросы, используя методы Search
или SearchStream
. Оба метода поддерживают одни и те же запросы и возвращают эквивалентные результаты. Метод Search
возвращает данные на страницах фиксированного размера по 10 000 строк, что позволяет перебирать набор результатов с помощью разбиения на страницы. Это может быть выгодно при низкой пропускной способности или ненадежности сети, например, для разделения большого набора результатов на более мелкие ответы, которые можно будет повторно получить в случае потери соединения. С другой стороны, метод SearchStream
передает весь набор результатов обратно в один ответ, что может быть более эффективно для массового извлечения данных.
И Search
, и SearchStream
используют один и тот же базовый URL-адрес:
https://googleads.googleapis.com/v18/customers/CUSTOMER_ID/googleAds
POST /v18/customers/CUSTOMER_ID/googleAds:search 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'" }
Если в результатах более 10 000 строк, в ответе возвращается nextPageToken
:
{ "results": [ // ... // ... // ... ], "nextPageToken": "CPii5aS87vfFTBAKGJvk36qpLiIWUW5SZk8xa1JPaXJVdXdIR05JUUpxZyoCVjMwADjUBkD___________8B", "fieldMask": "adGroupCriterion.keyword.text,adGroupCriterion.status" }
Повторение того же запроса с добавлением pageToken
со значениями из предыдущего запроса приводит к получению следующей страницы результатов:
POST /v18/customers/CUSTOMER_ID/googleAds:search 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'", "pageToken": "CPii5aS87vfFTBAKGJvk36qpLiIWUW5SZk8xa1JPaXJVdXdIR05JUUpxZyoCVjMwADjUBkD___________8B" }
Чтобы использовать метод SearchStream
, который возвращает все результаты в одном потоковом ответе, измените метод службы в URL-адресе на searchStream
( для SearchStream
не требуется pageToken
):
POST /v18/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'" }