Как автоматизировать PPC-отчетность с помощью языка R, Google Таблиц и Data Studio

Любому РРС-специалисту знакома ситуация, когда наступает время отчетов и приходится долго и скрупулезно вносить данные в таблицу. Можно, конечно, спихнуть работу на джуниора. Однако потом все равно придется лично все проверять. Кроме того, для некоторых проектов отчетность становится настолько сложной и развернутой, что работой над ней занимается уже целая комaнда.
Проект, которым занимается наша комaнда — это OLX. Несколько стран, десяток направлений деятельности (от детской одежды до недвижимости), тысячи поисковых кампаний в Google Ads и Yandex Direct, а также множество медийных активностей в Facebook. Работа с таким большим проектом требует четкого контроля и подробной отчетности.
В какой-то момент старые методы автоматизации (Supermetrics, прямой парсинг данных в Data Studio, расширения Google Ads и ***ytics для доксов) перестали справляться с объемом данных. Они не давали необходимой чистоты и уровня детализации, а затраты времени на поддержание и контроль этой системы стали стремительно расти. Кроме того, сама структура отчетности устаревала как информационно, так и визуально.
В поиске решения этой проблемы я и пришел к способу, который опишу в цикле статей — «Как автоматизировать РРС-отчетность, не используя платных решений и без глубокого погружения в программирование». Вы читаете первый пост цикла.
Важно: мой способ — не волшебная таблетка, и здесь не будет готовых решений на все случаи жизни.
Итак, что нам понадобится:
- Среда разработки RStudio (да, совсем без программирования никак).
- Google Таблицы.
- Google Data Studio.
Почему именно эти инструменты?
По порядку:
1. Язык R. У него конкретное назначение — это язык программирования для статистической обработки данных и работы с графикой. Почему не Python? Действительно, Python более универсален и с его помощью можно решать больший перечень задач. Но в нашем случае его универсальность и многозадачность скорее минус — дольше разбираться.
Кроме того, конкретно для интернет-маркетологов по R есть множество обучающих материалов от Алексея Селезнева, например, бесплатный курс по основам R, каналы R4marketing в Telegram и на YouTube, множество статей в Netpeak Journal, на GitHub и других ресурсах, а также платный курс по R для тех, кто хочет полноценно разобраться в возможностях этого инструмента для автоматизации сбора данных.
2. Google Таблицы. Во-первых — возможность интеграции с R и Data Studio, во-вторых — привычность и удобство использования. Почему не BigQuery? На старте BigQuery — достаточно сложный инструмент, к тому же платный (хотя и недорогой), и кроме того — не всем нужно работать с большими объемами данных, поэтому возможностей Spreadsheets будет достаточно.
3. Google Data Studio. Простой, удобный и бесплатный инструмент, который позволяет визуализировать и красиво оформлять данные, а также доступен онлайн, благодаря чему отчетами удобно делиться как внутри комaнды, так и с клиентами.
Какие типы задач можно решить с помощью этих инструментов?
Контроль бюджетов
Структура проекта OLX такова, что нашей комaнде из четырех специалистов необходимо контролировать несколько десятков отдельных бюджетов в разных аккаунтах и в разных валютах. При этом из-за больших объемов трафика цена ошибки очень велика. Кроме того, отдельным направлением деятельности является работа с B2B-клиентами OLX, а это, на момент написания статьи, более 70 самостоятельных мини-проектов, каждый со своими отдельными бюджетами, сроками работы и KPI.
Для контроля B2B-проектов с помощью приведенных выше инструментов мы реализовали отчет, который позволяет увидеть все необходимые данные по всем клиентам сразу или по каждому отдельно.
Кому подойдет подобное решение?
- РРС-специалистам с большим количеством проектов;
- тимлидам для контроля трат по проектам комaнды;
- комaндам больших проектов для контроля бюджетов по разным направлениям.
Стандартизированная отчетность для типовых клиентов
Если у вас множество похожих проектов, для них можно создать стандартные отчеты, в которые можно подтягивать скриптом необходимые данные, не тратя время на сбор отчетов для каждого проекта отдельно.
Для тех же B2B-проектов мы реализовали автоматическую ежедневную отчетность по основным показателям.
Кому подойдет подобное решение?
- РРС-специалистам с большим количеством проектов.
- РМ-ам для предоставления быстрой отчетности клиентам.
- тимлидам для проверки результатов по проектам комaнды.
Углубленная отчетность для крупных клиентов
При необходимости можно строить отчеты по десяткам параметров и показателей из разных источников во множестве разрезов. Такие отчеты показывают проблемы или точки роста проекта, поэтому не придется каждый раз проводить исследование, чтобы проверить ту или иную гипотезу.
Например, для OLX мы реализовали развернутый отчет, с помощью которого можно в любой момент получить необходимые данные в нужном разрезе, не тратя время на то, чтобы «добыть» их в разных аккаунтах и системах аналитики.
Разумеется, подобные отчеты необходимы больше специалистам, чем клиенту. Для новичка или не вовлеченного глубоко в проект человека они могут показаться «перегруженными».
Кому подойдет подобное решение?
- комaнде РРС-специалистов на энтерпрайз проектах для поиска проблем и точек роста;
- аналитикам на крупных проектах; специалистам со стороны клиента;
- тимлидам для проверки результатов по проектам комaнды.
Решение повторяющихся задач
Если существует необходимость достать какие-либо данные, и при этом есть вероятность, что данные придется доставать регулярно, лучше реализовать это через скрипт. При должном навыке, написание скрипта займет столько же времени, сколько и заполнение отчета вручную (а может и быстрее). Зато при повторном выполнении задачи нужно будет всего лишь запустить сохраненный скрипт.
Кому подойдет подобное решение?
- любому специалисту, который работает с данными и хочет повысить эффективность своей работы.
С чего начать?
Прежде, чем браться за новое, нужно привести текущие дела в порядок. В нашем случае это значит, что для старта следует привести к единой структуре и общему виду аккаунты, из которых будем тянуть данные.
Тезис кажется очевидным, но это далеко не во всех случаях так. Часто в больших и старых аккаунтах кампании создаются не просто разными специалистами, но и разными «поколениями» специалистов. В итоге структура одних кампаний может сильно отличаться от структуры других, а почему она именно такая, и какая логика в это закладывалась — никто уже не помнит.
Носитель знаний по кампаниям уже сменил десятую работу и состарился. Кампании осталось в текущем виде, потому-что «так исторически сложилось» и ни у кого не доходят руки всё это разгрести. Работает и работает, есть задачи и поважнее, вон срочно нужно запустить акцию.Поэтому, первым делом, необходимо прописать структуру ваших кампаний. То есть натурально взять и расписать на листе бумаги или в онлайн доксе:
- что к чему должно относится в вашем аккаунте;
- зачем всё это здесь;
- как и почему называется именно так.
Затем внимательно просмотрите ваш аккаунт. Когда пропишете структуру так, как вы её понимаете, и посмотрите, как она выглядит на самом деле, скорее всего найдете множество несоответствий, лишнего или недостающего.
Далее нужно браться за чистку «авгиевых конюшен». Если в названии кампаний или групп указывается, например, язык — везде должно быть только «ua» в нижнем регистре, а не «uk», «укр» и «UA» одновременно. Если платформа — везде desktop, каждый разделитель на своем месте, ну и так далее. У вас должна быть возможность выделить любой нужный вам сегмент. И чем меньше для этого нужно указать вариантов написания фильтров — тем лучше.
В идеале — пропишите единые правила нейминга для кампаний, покуда правила не станут для всех как «Отче наш».
Например, нейминг для групп объявлений мы реализовали так:
В процессе создания структуры кампаний, в названия сразу необходимо закладывать составляющие, по которым вы будете строить отчеты.
В идеале все кампании и группы должны попадать под фильтры «без пустого остатка».
Например, в данном примере отчета есть несколько фильтров и какую из комбинаций фильтров не задай, для нее будет свое соответствие. И наоборот, если отключить все варианты в фильтрах — не останется неучтенной кампании.
Установка языка R и среды разработки RStudio
Итак, теперь ваши аккаунты четкие, а это значит, что пришла пора «делать дела».
Начинаем с установки самого языка, так как RStudio — это оболочка R для упрощения работы с ним. Если сделать наоборот, вас всё равно заставят сначала установить R, но окольными путями и с лишними телодвижениями.
Приступим к установке R и RStudio.
- Ссылка для установки языка R. Никаких специальных настроек, просто соглашаемся со всем, что предлагает установщик.
- Ссылка для установки RStudio. Выбираем бесплатную версию RStudio Desktop.
Также соглашаемся со всеми пунктами, улыбаемся и машем.
Когда через секунды полторы вам станет больно от стандартной темы RStudio, откройте на панели инструментов «Tools» — «Global options» — «Appearance» и выберите настройки темы для себя.
Взаимодействие пользователя RStudio с рекламными аккаунтами происходит через их API посредством специальных пакетов R для этих сервисов. Авторизация осуществляется по протоколу OAuth 2.0, вместо логина и пароля используются токены.
Авторизация и доступ к API рекламных сервисов — это отдельная история. Далее я опишу, как получить возможность взаимодействовать с основными рекламными сервисами.
Установка пакета google***yticsR и авторизация
Пакет google***yticsR предназначен для работы с API Google ***ytics.
Работа с любым API начинается с авторизации.
Перед тем, как сделать свой первый запрос к API Google ***ytics, необходимо пройти несколько подготовительных шагов:
- выбрать наиболее подходящий способ авторизации;
- при необходимости создать проект в Google Cloud, если его ещё нет;
- создать ключ сервисного аккаунта или обычные учетные данные;
- если создали сервисный аккаунт, дать на его почтовый адрес доступ к нужным аккаунтам Google ***ytics;
- при необходимости создать переменные среды;
- включить API Google ***ytics.
Существуют такие способы авторизации в google***yticsR:
- со стандартными параметрами пакета;
- через собственное приложение, созданное в Google Cloud Console;
- через сервисный аккаунт.
Самый простой способ авторизации — использование комaнды ga_auth() со стандартными значениями аргументов, установленными по умолчанию. Большинство пользователей проходят авторизацию именно так, но вы можете столкнуться с лимитом 50 000 запросов к API в сутки.
Подключение API ***ytics
Также необходимо включить Google ***ytics API. Сделать это можно через библиотеку в Google Cloud Platform. Либо перейдите по прямым ссылкам и включите там:
1. Google ***ytics Reporting API.
Включенные API выглядят так:
Запуск пакета google***yticsR в RStudio и авторизация
Для установки пакета в R необходимо запустить (Ctrl+Enter) в консоли комaнду install.packages(название пакета). Эту комaнду нужно запустить один раз при установке пакета.
Для запуска пакета запустите комaнду library(название пакета):
install.packages(\"google***yticsR\") # установка библиотеки для работы с Google ***ytics
library(google***yticsR) # запуск библиотеки для работы с Google ***ytics
Для запуска авторизации в R используйте комaнду:
# Авторизация в Google ***ytics
ga_auth(email=\"youremail@gmail.com\")
Далее следуйте инструкциям RStudio.
О более продвинутых способах авторизации (через собственное приложение и через сервисный аккаунт) есть видео на канале R4marketing и статья Алексея Селезнева. Рекомендую вам самостоятельно изучить и опробовать их.
Установка пакета RAdwords и прохождение авторизации
Пакет RAdwords предназначен для работы с API Google Ads.
Прежде, чем мы начнем разбираться с пакетом для работы с Google Ads, предупреждаю, что получить доступ к его API — достаточно длительный и трудный процесс. Большую часть вопросов по Google Ads можно закрыть через парсинг данных из отчетов по Google ***ytics и по Google Ads, куда проще получить доступ.
Если же вам необходимы данные именно из Google Ads, и вы не боитесь трудностей — вперед!
Получение доступа к API Google Ads
Для доступа к API вам необходимо:
- Создать центр клиентов. Перейдите по этой ссылке и зарегистрируйте новый центр клиентов (МСС). Обратите внимание, что центр клиентов можно создать только в том аккаунте Google, к которому ещё не привязан ни один аккаунт Google Ads.
- Подать заявку на доступ к API. Перейдите в «Инструменты» (значок гаечного ключа в правом углу) — «Дополнительные инструменты» — «Центр API». Заполните все поля и примите условия использования. После создания идентификатора заполните заявку на уровень доступа.
Актуальная информация о том, как получить доступ к API Google Ads — в официальной справке.
- Далее вашу заявку рассмотрят и одобрят (но это не точно).
- Создать приложение в Google Cloud.
- войдите в управляющий аккаунт, откройте страницу «Учетные данные» в Google Developers Console и создайте новый проект;
- далее жмём кнопку «Создать учётные данные» и выбираем «Идентификатор клиента OAuth»;
- если система предложит указать название продукта, нажмите «Настроить окно запроса доступа»;
- укажите запрашиваемую информацию и нажмите «Сохранить», чтобы вернуться к экрану «Учетные данные»;
- в разделе «Тип приложения» выберите «Приложение для ПК»;
- укажите название в появившемся поле; нажмите кнопку «Создать». Появятся идентификатор и секретный ключ клиента OAuth2. Скопируйте и сохраните их. На следующем шаге их нужно будет добавить в файл конфигурации.
Запуск пакета RAdwords в RStudio и авторизация
Установка пакета:
install.packages(\"RAdwords\") # установка библиотеки для работы с Google Ads
library(RAdwords) # запуск библиотеки для работы с Google Ads
Если доступы к API получены, вы можете пройти авторизацию в RStudio:
# Авторизация в Google Ads
ads_auth <- doAuth()
# Идентификатор в Google Ads
account_id <- \"123-456-7890\"
Далее следуйте инструкциям RStudio.
Ещё раз подумайте, следует ли вам заморачиваться с заявками на доступ к API, и не хватит ли вам для ваших целей возможностей Google Аналитики.
Установка пакета rfacebookstat и прохождение авторизации
Пакет rfacebookstat предназначен для работы с API Facebook.
Авторизация через fbAuth()
Самый простой способ авторизации в rfacebookstat — через запуск комaнды fbAuth() и встроенное в пакет приложение. Предоставив необходимые разрешения пакету, вы перенаправитесь на страницу rfacebookstat на github, где сгенерируется краткосрочный токен.
Этот токен вы копируете и вставляете в консоль R для прохождения авторизации. Далее вам предложат сохранить токен, и он станет долгосрочным.
Авторизация через собственное приложение
Ещё один вариант авторизации — через создание собственного приложения в Facebook.
- Создайте приложение в веб-интерфейсе Facebook, перейдя по ссылке.
- Нажмите кнопку «Создать приложение», которая находится в правом углу.
- Выберите назначение «Управление бизнес-интеграциями».
- Заполните необходимые поля.
5. Добавьте продукты «API Marketing» и «Вход через Facebook».
6. В настройках продукта «Вход через Facebook» установите в качестве «Действительные URL» перенаправления для OAuth ссылку — https://selesnow.github.io/rfacebookstat/getToken/get_token.html.
Для авторизации через свое приложение в качестве аргументов функции fbAuth() вам понадобится информация по идентификатору и секрету созданного приложения. Найти эту информацию можно в его настройках, в меню «Основное».
Запуск пакета rfacebookstat в RStudio и авторизация
Установка пакета:
install.packages(\"rfacebookstat\") # установка библиотеки для работы с Facebook
library(rfacebookstat) # запуск библиотеки для работы с Facebook
Авторизация в RStudio через встроенное приложение:
# Авторизация в Facebook fbAuth()
Авторизация в RStudio через собственное приложение:
# Авторизация в Facebook
fbAuth(app_id = 1234567898765432,
app_secret = \"a5b02aabd4a3200346dc6f7895aebce1\")
Теперь вы сможете приступить к работе с пакетом rfacebookstat.
Установка пакета ryandexdirect и авторизация
Пакет ryandexdirect предназначен для работы с API Яндекс.Директ.
Самый простой в авторизации пакет для работы с рекламными системами — ryandexdirect (чего не скажешь про сам Директ). Не нужно никаких заявок, приложений и прочих танцев с бубном. По большому счету, даже комaнда авторизации не обязательна, так как она автоматически запускается при выполнении любой комaнды пакета.
Запуск пакета ryandexdirect в RStudio и авторизация
Установка пакета:
install.packages(\"ryandexdirect\") # установка библиотеки для работы с Яндекс.Директ
library(ryandexdirect) # запуск библиотеки для работы с Яндекс.Директ
Авторизация в RStudio:
# Авторизация в Яндекс.ДиректyadirAuth()
Далее следуйте инструкциям RStudio.
На этом заканчивается первая статья.
Заключение
Это подготовительная статья цикла постов по автоматизации РРС-отчетности. Из неё можно узнать:
- Какие типы задач можно решать с помощью данного метода автоматизации и кому он подойдет.
- Как подготовить аккаунты к автоматизации.
- Как установить язык R и среду Rstudio.
- Установка и авторизация пакетов для работы с рекламными системами.
Что будет в следующей статье:
- Примеры запросов для каждого из пакетов.
- Разбор полей и показателей запросов.
- Посмотрим документацию по API.
- Изучим способы преобразования данных.
- Дополнительные материалы для каждого из пакетов.
Комментарии:
Как собрать свой онлайн марафон на 500 или 1000 человек? Сколько это стоит и какие сервисы использовать. Давайте разбираться....
18 04 2026 6:50:15
Наконец-то вы создали сайт. Вы потратили усилия на дизайн, разработку, его наполнение. Но этого оказалось недостаточно, чтобы о вашем интернет- ресурсе узнали. Как же привлечь посетителей на сайт?...
17 04 2026 8:57:44
Детально заполняйте карточку товара, добавляйте качественные фотографии, делайте акцент на УТП....
16 04 2026 3:14:37
Объявление в тематике автошин — отличная тема для рекламы в интернете....
15 04 2026 16:59:38
Правильно выбранная соц. площадка поможет раскрутить бизнес эффективно....
14 04 2026 9:22:13
Используя для продвижения контекстную рекламу, большинство рекламодателей в Украине отдают предпочтение системе Google Ads. Директ однозначно не стоит недооценивать. Почему? Читайте в статье!...
13 04 2026 19:45:27
Как стандартизировали сбор данных по проектам клиентов и отчетности, чтобы тратить меньше времени и не совершать лишние действия...
12 04 2026 22:53:27
Чтобы создавать удобные отчеты, импортируйте данные из Яндекс.Директ в Microsoft Power BI с помощью язык R...
11 04 2026 21:24:48
Почему в рекламе недвижимости стоит запускать динамический ремаркетинг...
10 04 2026 3:57:33
Один из лучших способов выбрать подрядчика — провести брифинг для компаний. При этом важно предоставить максимум информации: откройте доступ к реальным данным по проекту. Узнать больше!...
09 04 2026 5:50:55
зеркальные нейроны и сознание. как они влияют на наше поведение?...
08 04 2026 4:50:40
Менеджмент и лидерство: 4 разных типа руководства организацией и нескучные иллюстрации в стиле South park....
07 04 2026 18:33:17
Как правильно мотивировать и демотивировать себя — теория и кейсы. Как бросить курить, начать бегать и наконец-то приступить к изучению английского. Читать!...
06 04 2026 3:40:23
Как улучшить видимость сайта после оптимизаторов-староверов — кейс в тематике «световое и звуковое оборудование»....
05 04 2026 6:12:28
Николь Лаззаро из XEODesign провела исследование о том, почему мы играем или не играем в игры....
04 04 2026 5:15:54
Гайд по типам рекламы в соцсетях для SMM-, PPC-специалистов, блогеров и владельцев бизнеса в зависимости от целей, которые вы ставите перед продвижением. С конкретными рекомендациями и примерами. Узнать больше!...
03 04 2026 3:10:22
SEO-специалисты используют создание поддоменов, подпапок или отдельных доменов...
02 04 2026 14:30:50
Сайту нужны внешние ссылки на сторонних ресурсах. Они могут повлиять на ранжирование вашего ресурса и трафик, а один из методов их получить — аутрич....
01 04 2026 17:46:58
Инструменты интернет-маркетинга, которые вы не используете или используете не на сто процентов....
31 03 2026 17:45:45
Эта история о том, как за два года комплексный подход к поисковому продвижению (SEO на этапе разработке сайта и дальнейшие действия по оптимизации) помог увеличить рост бесплатного трафика на 463% или Что делать, если SEO не приносит результаты сразу...
30 03 2026 16:15:17
Свежесть и актуальность контента — главные уроки из Google December 2020 Core Update. Почему — читайте в статье....
29 03 2026 20:16:13
Есть офлайн-точка продаж и нужно привлечь сюда больше клиентов. Что делать? Настраиваем локальные кампании. Показываем и рассказываем, как это делать....
28 03 2026 10:40:34
Facebook buttons. Пора поделиться самым волнующим вопросом 2011-го года...
27 03 2026 6:15:57
Самые точные данные статистики, которые вы получите с помощью Google Tag Manager....
26 03 2026 6:31:31
Новости для наших существующих и потенциальных клиентов....
25 03 2026 21:34:41
Понятный алгоритм анализа поисковых запросов с экономией времени на чистку по специальному шаблону модерации...
24 03 2026 9:44:23
Структура обзора, правила написания и важные хаpaктеристики этого формата. Подача информации в обзоре и запрещенные методы, которые отпугнут клиентов. Узнать больше!...
23 03 2026 23:15:46
Сколько стоил клик в Google Ads и Яндекс.Директ в Казахстане — цифры за первый квартал 2019 года...
22 03 2026 7:14:42
Как разобраться в типах соответствия ключевых слов и определить, что минус-слова блокируют показы нужных ключевых слов....
21 03 2026 13:51:30
Что такое идеальное время доставки почты и как его использовать для повышения кликабельности email-кампаний....
20 03 2026 1:15:49
Создаем фид с помощью выгрузки товаров в формате yml и специального скрипта, который сделает всю (почти) грязную работу за вас....
19 03 2026 13:57:27
Какие рассылки можно отправить покупателю, если у вас есть только данные из карточки товара...
18 03 2026 10:50:29
У нас на руках оказались все карты для создания собственного мини-рейтинга популярных сервисов email-рассылок....
17 03 2026 1:52:54
За какими метриками следует пристально следить в email-рассылках...
16 03 2026 4:14:16
Сотрудник не справляется? Значит с ним пора прощаться. Эмоции в сторону, действуем по алгоритму....
15 03 2026 1:13:13
Что такое теневой бан, что о нем известно, как выйти из-под него. Плюс мнение SMM-эксперта Нели Серебро...
14 03 2026 5:36:53
Проведение краудфандинговых кампаний — это бизнес. Это отдельный и вполне серьёзный рынок с уймой заточенных под ваши нужды услуг. Раньше нужно было ждать, пока проект пройдет обязательную проверку сотрудником Kickstarter, сейчас можно запускать кампанию...
13 03 2026 18:21:10
Увеличение трафика из поисковых систем Азербайджана на 30% за три месяца. И он продолжает расти...
12 03 2026 11:30:50
Лафхаки для маркетологов и владельцев сайтов на Prom...
11 03 2026 18:52:32
Заказчик всегда приходит с идеей. В этой идее может быть все продумано до мелочей, а может быть только каркас. В любом случае мысли клиента следует систематизировать так, чтобы с ними было удобно работать....
10 03 2026 19:57:34
Данные по 24 миллионам кликов в 24 тематиках и 391 городу...
09 03 2026 15:50:27
Требования к интернет-магазину, мануал по регистрации, что может пойти не так...
08 03 2026 11:46:10
Как превратить неактивных подписчиков в вовлеченную аудиторию....
07 03 2026 14:45:43
Пришло такое время — обновить данные, тем более что в начале сентября появилось исследование Google....
06 03 2026 0:20:16
Подобрать нужные слова поможет проверка Google Рекламы....
05 03 2026 20:30:19
Как создать популярный и удобный магазин в интернете, какой должна быть его раскрутка и многое другое, прозвучавшее на круглом столе 8P 2017...
04 03 2026 20:36:54
Сегодня мы открываем новую регулярную серию постов, в которых будем стараться раз в квартал рассказывать про семь важных улучшений Netpeak в работе с клиентами. Сейчас мы максимально сфокусированы на SEO и PPC....
03 03 2026 9:20:30
Facebook + Instagram, Business Manager + основная бизнес-страница на Facebook, BM + рекламный аккаунт и так далее....
02 03 2026 20:39:25
Что, если бы покупка в супермаркете происходила так же, как в онлайн-магазине?...
01 03 2026 4:17:23
Мы собрали 30+ Телеграм-каналов, где вы найдете только полезную и актуальную информацию про маркетинг, SEO, SMM, веб-аналитику и развитие бизнеса...
28 02 2026 18:13:45
Еще:
понять и запомнить -1 :: понять и запомнить -2 :: понять и запомнить -3 :: понять и запомнить -4 :: понять и запомнить -5 :: понять и запомнить -6 :: понять и запомнить -7 ::