Выгрузка данных отчетов 1С в Power BI для аналитиков

01.08.22

Интеграция - Внешние источники данных

Как я решил проблемы выгрузки данных в Power BI для нашего аналитика. Запрос был на то, чтобы грузить результат уже готовых отчетов 1С и меньше вычислительных действий производить на стороне Power BI. Некоторые из отчетов имели в себе результирующие данные в количестве от 300 000 до 500 000 строк за каждый месяц. Часть таблиц должна была выгружаться по регламенту каждый день, вторая часть выгружается только по потребности. Обработка в настоящее время безошибочно работает на 1С:Предприятие 8.3 (8.3.20.1838), конфигурация Управление торговлей, редакция 11.1 (11.1.4.14).

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
Выгрузка данных отчетов 1С в Power BI для аналитиков.:
.epf 13,05Kb ver:1.0
8 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Выгрузка данных отчетов из 1С в Power BI

       Полный цикл выгрузки данных. 

  1. Создаем таблицу для хранения данных на SQL сервере.
  2. Из обработки в 1С подключаемся к серверу и к таблицам. 
  3. Удаляем старые данные из таблицы на сервере для ввода новых. (Так происходит обновление данных).
  4. Отправляем запросы удаления данных на SQL сервер.
  5. Получаем данные из запроса 1С.
  6. Формируем данные для отправки и отправляем. 
  7. В Power BI настраиваем загрузку данных из SQL сервера и получаем готовые данные. 

 

  • Создаем таблицу для хранения данных на SQL сервере.

Самостоятельно или через системного администратора создаем базу данных "PowerBI" и создаем нужные нам таблицы. 
Правила и принципы создания таблиц на SQL сервере можно посмотреть тут:
Как создать таблицу в SQL.

Очень важно уделить внимание названию таблиц, так как потом названия таблиц будут отображаться у аналитика в программе PowerBI, и лучше если таблицы будут называться логично но латиницей. 

  • Из обработки в 1С подключаемся к серверу и к таблицам.
Функция ВыполнитьПодключениекСерверу()Экспорт

	Connection = Новый COMОбъект("ADODB.Connection");
	Провайдер = "SQLOLEDB"; // имя провайдера ODBC, чаще всего указывается именно такой
	СРВ = "srv1c-sql.*****.local";
	БД = "PowerBI";
	УИД = "PowerBI";
	ПВД = "111-111111";
	СтрокаПодключения = "Provider=" + Провайдер + "; Persist Security Info=False; Server=" + СРВ + ";Database=" + БД + ";UID=" + УИД + ";PWD=" + ПВД + ";";
	Connection.CommandTimeOut = 0;
		
Connection.Open(СокрЛП(СтрокаПодключения)); 
Возврат Connection;
	
КонецФункции
  • Удаляем старые данные из таблицы на сервере для ввода новых. (Так происходит обновление данных)

Удаление данных происходит двумя способами, а точнее по двум сценарием. 
Первый: если таблица содержит в себе до 50 000 записей (справочники партнеры, номенклатура, склады, регионы и так далее), то таблицу можно удалить полностью и полностью загрузить. 
Второй сценарий: удаление записей по определенному периоду. Такую процедуру можно использовать, когда таблица содержит от 50 000 записей и обновление требуется только текущего дня или недели или месяца (данные отчета продажи, остатки, обороты, выручка).
Приведу пример второго варианта работы с таблицей. 

  • Отправляем запросы удаления данных на SQL сервер.

Сначала проверяем, есть ли подключение к серверу.
Затем, если период не выбран, то устанавливаем в качестве границ удаления начало и конец текущего месяца.
Формируем текст запроса для SQL с указанием названия таблицы и параметрами периода.
Выполняем отправку нашего запроса. Ответ от сервера мы не получаем, потому что для проверки можно открыть SQL Server Management Studio и проверить таблицу. 

Процедура ПроверитьЗаполненностьТаблицыПродажи(НачалоПериода,КонецПериода) Экспорт
	
	Connection = ВыполнитьПодключениекСерверу();

	Если НЕ ЗначениеЗаполнено(НачалоПериода) или НачалоПериода = Дата("00010101") Тогда
		НачалоПериода   	= НачалоМесяца(ТекущаяДата());
		КонецПериода 	    = КонецМесяца(ТекущаяДата());	
	КонецЕсли;
	
	Если Connection = Неопределено Тогда
	    Возврат;
	КонецЕсли;
	RecordSet                = Новый COMОбъект("ADODB.Recordset");
	Command                  = Новый COMОбъект ("ADODB.Command");
	Command.ActiveConnection = Connection;
	ЗапросНаСайте =
	"DELETE FROM dbo.total_sales1 WHERE date_sales >=CAST('"+Формат(НачалоПериода,"ДФ=гггг")+Формат(НачалоПериода,"ДФ=ММ")+Формат(НачалоДня(НачалоПериода),"ДФ=дд")+"' AS date) "
	"and date_sales <=CAST('"+Формат(КонецПериода,"ДФ=гггг")+Формат(КонецПериода,"ДФ=ММ")+Формат(НачалоДня(КонецПериода),"ДФ=дд")+"' AS date)";
	
	Command.CommandTimeout = 100;
	Command.CommandText    = ЗапросНаСайте;
	Command.CommandType    = 1;

	Connection.Close();
КонецПроцедуры
  • Получаем данные из запроса 1С.

После удаления данных таблицы переходим к её заполнению. Процедуру выгрузки данных поместил в "Попытку", что бы в случае возникновения проблем понять, что не так.

	Попытка
		RecordSet = Command.Execute();
		ВыгрузитьСписокПродаж(НачалоПериода,КонецПериода);	
		//ЗаписьЖурналаРегистрации(НСтр("ru = 'Выгрузка продажи Power'",),
		//УровеньЖурналаРегистрации.Информация, , ,НСтр("Продажи выгрузились'",));
		//Connection.Close();
		//Возврат;
	Исключение
		ЗаписьЖурналаРегистрации(НСтр("ru = 'Выгрузка продажи Power не прошла'", ),
		УровеньЖурналаРегистрации.Информация, , ,ЗапросНаСайте + " "+ОписаниеОшибки(),);
		Connection.Close();
		Возврат;
	КонецПопытки;

Получаем выгрузку из запроса и передаем его дальше для обработки каждой строки. Пример получения данных и выгрузки покажу на номенклатуре. 
В цикле по каждой номенклатуре начинаем формировать нашу строку запроса. Если данные еще не были отправлены и количество строк в запросе к SQL = 0, тогда в текст запроса добавляем шапку запроса и идем дальше.
В строку добавляем временные параметры по количеству строк таблицы.
Заменяем наши временные параметры значениями из запроса и добавляем к исходной строке запроса. 

Выгружать строки можно как по одной, так и по несколько строк в одном запросе. Для этого мы и считали, сколько строк уже обработано. Если количество обработанных строк достигло нужного количества, то мы обрабатываем запрос для безошибочного выполнения (удаляем лишнюю запятую в конце запроса) и отправляем запрос на сервер. И так до конца цикла.  

Процедура ВыгрузитьСписокНоменклатур()
    Connection = ВыполнитьПодключениекСерверу(); // одна из трех вышеописанных функций
    Если Connection = Неопределено Тогда
        Возврат;
    КонецЕсли;
    RecordSet = Новый COMОбъект("ADODB.Recordset");
    Command = Новый COMОбъект ("ADODB.Command");
    Command.ActiveConnection = Connection;
	
	СписокНоменклатур = ПолучитьСписокНоменклатур();
	
	СчетчикСтрок = 0;
	ДанныеОтправлены = Ложь;
	Для Каждого Номенк из СписокНоменклатур Цикл
		Если ДанныеОтправлены Тогда
			СчетчикСтрок = 0;
			ДанныеОтправлены = Ложь;
		КонецЕсли;
		Если СчетчикСтрок = 0 Тогда
			ЗапросДобавленияОстатков = 
			"INSERT
			|INTO dbo.nomenclature_table (GUID,nomenclature_name,group_1)
			|Values ";
		КонецЕсли;
		
		ЗапросДобавленияОстатков = ЗапросДобавленияОстатков + "('@1param','@2param','@3param'),";
		
		ЗапросДобавленияОстатков = СтрЗаменить(ЗапросДобавленияОстатков,"@1param",Номенк.Ссылка.ГУИД);
		ЗапросДобавленияОстатков = СтрЗаменить(ЗапросДобавленияОстатков,"@2param",СтрЗаменить(Номенк.Ссылка,"'"," "));
		ЗапросДобавленияОстатков = СтрЗаменить(ЗапросДобавленияОстатков,"@3param",Номенк.Поле1);
		
		СчетчикСтрок = СчетчикСтрок + 1;
		
		Если СчетчикСтрок = 5 Тогда
			ЗапросКSQL = Сред(ЗапросДобавленияОстатков,0,СтрДлина(ЗапросДобавленияОстатков)-1);
			Command.CommandText = ЗапросКSQL;
			Command.CommandType = 1;
			Попытка
				RecordSet = Command.Execute();
				ЗапросДобавленияОстатков = "";		
				//ЗаписьЖурналаРегистрации(НСтр("ru = 'Выгрузка Power'", ),
				//УровеньЖурналаРегистрации.Информация, , ,НСтр("ru = 'Выгрузка Прошла'", ));
				ДанныеОтправлены = Истина;
			Исключение
				//Сообщить ("Не удалось экспортировать остатки товара: " + Документ.Номенклатура +" по партнеру "+Документ.Партнер);
				//Сообщить (ОписаниеОшибки());
				//Сообщить(Документ.Количество);
				ЗаписьЖурналаРегистрации(НСтр("ru = 'Выгрузка Power номенклатура Ошибка'", ),
				УровеньЖурналаРегистрации.Информация, , ,ОписаниеОшибки()+" "+ЗапросКSQL,);
				Connection.Close();
				Возврат;
			КонецПопытки;
		КонецЕсли;
	КонецЦикла;
	Connection.Close();
	ЗаписьЖурналаРегистрации(НСтр("ru = 'Выгрузка Power Номенклатура завершена'", ),
	УровеньЖурналаРегистрации.Информация, , ,ТекущаяДата(),);

КонецПроцедуры 

Если цикл завершился, но количество сформированных строк меньше, чем необходимо для отправки, можно после цикла добавить дополнительную проверку с отправкой запроса. 

Если НЕ ДанныеОтправлены Тогда
		ЗапросКSQL = Сред(ЗапросДобавленияОстатков,0,СтрДлина(ЗапросДобавленияОстатков)-1);
		Command.CommandText = ЗапросКSQL;
		Command.CommandType = 1;
		Попытка
			RecordSet = Command.Execute();
			ЗапросДобавленияОстатков = "";		
			//ЗаписьЖурналаРегистрации(НСтр("ru = 'Выгрузка Power'", ),
			//УровеньЖурналаРегистрации.Информация, , ,НСтр("ru = 'Выгрузка Прошла'", ));
			ДанныеОтправлены = Истина;
		Исключение
			//Сообщить ("Не удалось экспортировать остатки товара: " + Документ.Номенклатура +" по партнеру "+Документ.Партнер);
			//Сообщить (ОписаниеОшибки());
			//Сообщить(Документ.Количество);
			ЗаписьЖурналаРегистрации(НСтр("ru = 'Выгрузка Power номенклатура Ошибка'", ),
			УровеньЖурналаРегистрации.Информация, , ,ОписаниеОшибки()+" "+ЗапросКSQL,);
			Connection.Close();
			Возврат;
		КонецПопытки;
КонецЕсли;

  Все. Данные отправлены на SQL Server. Это можно проверить через SQL Server Management Studio. Осталось только получить данные в Power BI. 

А дальше уже работа аналитика по настройке и связям таблиц в Power BI.

Экстрактор данных из 1С в BI-системы

Готовое решение для автоматической выгрузки данных из 1С 8.3 в базу данных ClickHouse, PostgreSQL или Microsoft SQL для работы с данными 1С в BI-системах:

«Экстрактор данных 1С в BI» работает со всеми типовыми и нестандартными конфигурациями 1С 8.3 и упрощает работу бизнес-аналитиков, программистов, финансовых и технических директоров.

Простое подключение к системам BI позволит вести углубленный анализ данных и эффективно отлаживать бизнес-процессы.

Тестировать бесплатно 5 дней

Вступайте в нашу телеграмм-группу Инфостарт

Обработка Power BI выгрузка данных из загрузка в power bi интеграция с

См. также

Внешние источники данных Программист Бизнес-аналитик Пользователь 1С v8.3 Управляемые формы Анализ и прогнозирование 1C:Бухгалтерия Узбекистан Беларусь Кыргызстан Молдова Россия Казахстан Платные (руб)

Готовое решение для автоматической выгрузки данных из 1С 8.3 в базу данных ClickHouse, PostgreSQL или Microsoft SQL для работы с данными 1С в BI-системах. «Экстрактор данных 1С в BI» работает со всеми типовыми и нестандартными конфигурациями 1С 8.3 и упрощает работу бизнес-аналитиков. Благодаря этому решению, специалистам не требуется быть программистами, чтобы легко получать данные из 1С в вашей BI-системе.

28500 руб.

15.11.2022    26251    29    49    

43

Внешние источники данных Программист Бизнес-аналитик 1С v8.3 1С:Управление производственным предприятием 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x 1С:Розница 3.0 Платные (руб)

Обработка для выгрузки данных из подготовленных СКД в фоновом режиме в базу ClickHouseDB, PostgreSQL, MySQL, REST (CSV, JSON, SQL) и локальные папки (CSV, JSON, XLS, XLSX). Это дополнительная подключаемая обработка.

18000 руб.

21.08.2024    4107    11    4    

11

Розничная торговля Внешние источники данных Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Бухгалтерский учет 1С:Бухгалтерия 3.0 Фармацевтика, аптеки Россия Бухгалтерский учет Платные (руб)

Внешняя обработка загрузки данных из файла-выгрузки, сформированного в программе F3 TAIL версии 3.4 (и выше) или еФарма версии 2.1, в базу конфигурации 1С: Бухгалтерия предприятия 8, ред. 3.0 (базовая, ПРОФ, КОРП, ФРЕШ).

13200 руб.

19.12.2016    50504    104    106    

75

Производство готовой продукции (работ, услуг) Внешние источники данных 1С v8.3 1С:Управление нашей фирмой 1.6 Лесное и деревообрабатывающее хозяйство Россия Управленческий учет Платные (руб)

Обработка предназначена для загрузки файлов, выгруженных из системы Базис-мебельщик, в справочник 1С "Спецификации" для последующих процессов учета и диспетчирования полуфабрикатов и изделий.

10200 руб.

24.06.2021    23334    58    55    

41

Внешние источники данных Банковские операции Бухгалтер 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия государственного учреждения Россия Бухгалтерский учет Платные (руб)

Обработки для загрузки данных из УРМ "Криста" в бухгалтерию государственного учреждения редакция 2.0. Есть Демо доступ на вкладке Бесплатные файлы на 1 месяц со дня получения демонстрационного ключа регистрации. Поддерживает ПО "Web-исполнение" от НПО "Криста".

4800 руб.

19.06.2013    41271    143    108    

36

Внешние источники данных Мастера заполнения Бизнес-аналитик Бухгалтер Пользователь 1С v8.3 Управляемые формы 1С:Бухгалтерия государственного учреждения 1С:Бухгалтерия 3.0 1С:ERP Управление предприятием 2 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 1.6 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 11 1С:Розница 3.0 1С:Документооборот Россия Платные (руб)

Решение позволяет по ИНН произвести проверку общих сведений, видов деятельности, данных ЕГРЮЛ, связанных организаций, отчетности, налогов, получить финансовый анализ контрагентов, а также заполнить карточки справочника клиентов и поставщиков по ИНН в программе 1С по данным государственных реестров ФНС и ЕГРЮЛ/ЕГРИП

2600 руб.

12.08.2025    655    2    1    

4
Для отправки сообщения требуется регистрация/авторизация