Выгрузка данных из amoCRM в Google Sheets


Автоматизируем выгрузку данных из amoCRM в Google Sheets с помощью MoreKIT.

Задача

Передаем данные из CRM в таблицу по событию в CRM.

В данном примере: выгрузка в таблицу ID сделки, фамилии и имени основного контакта в сделке и ответственного при создании новой сделки в выбранной воронке продаж и этапе.

результат выгрузки

Подготовка таблицы

Создаем таблицу и добавляем скрипт по инструкции.

Код скрипта:

function doPost(request) {
var data = JSON.parse(request.postData.contents),
sheet = SpreadsheetApp.getActive().getActiveSheet(),
table_headers = get_table_headers(sheet),
search_by = request.parameter.search_by;
if (table_headers.length == 0) {
table_headers = Object.keys(data);
fill_headers(sheet, table_headers);
}
if (!search_by) {
return ContentService.createTextOutput(JSON.stringify({'error': 'search_by not found'}));
}
if (is_object(data)){
var fill_func = fill_object;
if (is_array(data)) fill_func = fill_array;
fill_func(data, table_headers, sheet, search_by);
} else {

return ContentService.createTextOutput(JSON.stringify({'error': 'Unknown data format'}));
}

return ContentService.createTextOutput(JSON.stringify({'result': 'ok'}));
}

function is_array(data){
return typeof(data) === 'object' && data.length;
}

function is_object(data){
return typeof(data) === 'object';
}

function fill_array(data, table_headers, sheet, search_by){
data.forEach((v) => {fill_object(v, table_headers, sheet, search_by)});
}

function fill_object(data, table_headers, sheet, search_by){
var column_id = table_headers.indexOf(search_by);
if (column_id < 0) return;
var row = get_row_id_by_lead_id(data[search_by], column_id + 1, sheet),
data = object_to_list(data, table_headers);
sheet.getRange(row, 1, 1, data.length).setValues([data]);
}

function fill_headers (sheet, headers) {
sheet.getRange(1, 1, 1, headers.length).setValues([headers]);
}

function get_table_headers(sheet){
var cols = sheet.getLastColumn();
if (cols > 0)
return sheet.getRange(1, 1, 1, sheet.getLastColumn()).getValues()[0];
else
return [];
}

function object_to_list(data, table_headers){
var result = [];
for (i in table_headers){
result.push(data[table_headers[i]] || '');
}

return result;
}

function get_row_id_by_lead_id(lead_id, column, sheet){
var last_row = sheet.getLastRow();
if (last_row > 1){
var data = sheet.getRange(2, column, last_row, 1).getValues();
for (i in data){
if (data[i] && data[i][0] == lead_id) return parseInt(i) + 2;
}

}
return parseInt(last_row) + 1;
}

Создаем процесс

При создании процесса есть выбор его типа.

AmoCRM DP — позволяет собирать данные из выбранной воронки и этапа продаж. Ссылку в этом случае добавляем в Digital Pipeline.

AmoCRM вебхук — позволяет собирать данные из всей CRM. Ссылку в этом случае добавляем в Web Hooks в амоМаркет (справа вверху) и выбираем событие срабатывания.

Блок-схема процесса

Выстраиваем блок-схему, как на рисунке выше. Нужные блоки вытаскиваем из левого выпадающего меню.

Первый блок базовый и создается автоматически при создании нового процесса.

Блоки #1 и #2 из раздела подключенной CRM. Если в проекте более одной CRM? то вы будете видеть их все, поэтому выбирайте внимательно, из нужного раздела.

Блоки #3 и #4 из общих функций.

Настройка процесса

Стартовый блок

Cсылка создается автоматически. Её необходимо добавить в созданный хук на стороне CRM. При необходимости добавляем дополнительные проверки по полям, если нужны не все сделки.

Блок #1

  • Выбрать - "самый старый" — это стандартное поле, для определения выбора сделок при наличии дублей. В данном процессе оно не важно, так как работаем с одиночными сделками.

По входящему событию (создание новой сделки) ищем ID сделки.

Так же можно собирать любые поля из полученных данных.

Блок #2

По найденной сделке ищем основной контакт.

Блок #3

Используя данные найденной сделки получаем данные об ответственном за неё пользователе CRM.

Блок #4

Складываем данные в WebHook, с указанием необходимых собранных полей (ID сделки, название основного контакта, имя ответственного).

WebHook передает только ID клиента и ответственного, поэтому здесь мы уточняем их имя и фамилию (выбираем нужные поля).

Далее MoreKIT самостоятельно собирает из CRM данные по факту создания сделки и заполняет нужные поля в Google Sheets, согласно скрипту.

URL — адрес скрипта в Google.

GET-параметр — search_by параметр скрипта, который не даст создать дубли. Если сделка уже была добавлена то скрипт найдёт ID сделки в таблице и обновит данные по клиенту и ответственному. А при отсутствии, запишет значения в новую сроку.

В POST-параметрах указываем значения тех полей, которые нужно записать в таблицу. Скрипт сам создаст названия столбцов = название поля.

Результат

В результате получаем таблицу с автоматическим заполнением данных из CRM по определенным событиям.

К примеру:

  • список успешно завершенных сделок с ответственными и бюджетом сделок;
  • список закрытых неуспешно сделок с причинами отказов и ответственными;
  • список сделок с подписанными договорами;
  • успешные сделки с источниками ЛИДа, проданным продуктом, тегами и пр.