Оптимизация персонализированных рассылок отчетов в БСП

10.07.23

Интеграция - Email рассылки

Представленная в публикации разработка позволяет оптимизировать персонализированную рассылку отчетов БСП за счет предварительной выборки получателей отчетов.

Скачать файл

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

Наименование По подписке [?] Купить один файл
Оптимизация персонализированных рассылок отчетов в БСП:
.cfe 14,90Kb
3
3 Скачать (1 SM) Купить за 1 850 руб.

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

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

Таким образом, есть необходимость каким-то способом предварительно отобрать получателей отчета, по которым будут сформированы не пустые отчеты. В данной разработке предлагается следующий подход к решению поставленной задачи.

  1. Создать в отчете новую схему компоновки данных ОтборПолучателейОтчетов для отбора получателей рассылки с учетом возможных установленных отборов/параметров в отчете (то есть продублировать состав параметров/отборов рассылаемого варианта отчета). В качестве альтернативы вместо добавления новой схемы для отбора получателей также можно просто добавить новый вариант отчета с выбором получателей.
  2. В модуль объекта отчета добавить экспортную функцию СформироватьСписокПолучателейРассылки(), возвращающую таблицу получателей отчета. Таблица получателей формируется по СКД ОтборПолучателейОтчетов с учетом переданных пользовательских настроек (параметров/отборов) формируемого отчета.
  3. В процедуру ПередФормированиемСпискаПолучателейРассылки() общего модуля РассылкаОтчетовПереопределяемый добавить вызов функции СформироватьСписокПолучателейРассылки() модуля отчета. Скорректировать список получателей отчета по полученной таблице получателей.

Код процедуры ПередФормированиемСпискаПолучателейРассылки() общего модуля РассылкаОтчетовПереопределяемый:

Процедура ПередФормированиемСпискаПолучателейРассылки(ПараметрыПолучателей, Запрос, СтандартнаяОбработка, Результат)
	
	Персонализирована = ОбщегоНазначения.ЗначениеРеквизитаОбъекта(ПараметрыПолучателей.Ссылка, "Персонализирована");
	
	Если Персонализирована Тогда
		
		лЗапрос = Новый Запрос("ВЫБРАТЬ
		|	РассылкиОтчетовОтчеты.Отчет КАК ВариантОтчета,
		|	РассылкиОтчетовОтчеты.Настройки КАК Настройки
		|ИЗ
		|	Справочник.РассылкиОтчетов.Отчеты КАК РассылкиОтчетовОтчеты
		|ГДЕ
		|	РассылкиОтчетовОтчеты.Ссылка = &Ссылка
		|	И РассылкиОтчетовОтчеты.Отчет.Отчет В(&МассивОтчетов)");
		
		// массив отчетов с переопределением списка получателей для персонализированных рассылок
		МассивОтчетовСписокПолучателей = Новый Массив;
		МассивОтчетовСписокПолучателей.Добавить(ОбщегоНазначения.ИдентификаторОбъектаМетаданных("Отчет._ДемоФайлы"));
		
		лЗапрос.УстановитьПараметр("Ссылка", ПараметрыПолучателей.Ссылка);
		лЗапрос.УстановитьПараметр("МассивОтчетов", МассивОтчетовСписокПолучателей);
		Выборка = лЗапрос.Выполнить().Выбрать();
		Если Выборка.Следующий() Тогда
			ВариантОтчета = Выборка.ВариантОтчета;
			Настройки = Выборка.Настройки.Получить();
			
			Параметры = Новый Структура("СсылкаВарианта, ПользовательскиеНастройкиКД", ВариантОтчета, Настройки);
			Подключение = ВариантыОтчетов.ПодключитьОтчетИЗагрузитьНастройки(Параметры);
			
			тзПолучателей = Подключение.Объект.СформироватьСписокПолучателейРассылки();
			
			ТекстЗапроса = 
			"ВЫБРАТЬ
			|	ТаблицаПолучателейОтчета.Получатель
			|ПОМЕСТИТЬ ТаблицаПолучателейОтчета
			|ИЗ
			|	&ТаблицаПолучателейОтчета КАК ТаблицаПолучателейОтчета
			|;
			|
			|////////////////////////////////////////////////////////////////////////////////
			|" + Запрос.Текст;
			
			Схема = Новый СхемаЗапроса;
			Схема.УстановитьТекстЗапроса(ТекстЗапроса);
			
			Пакет = Схема.ПакетЗапросов[Схема.ПакетЗапросов.Количество()-1];
			Оператор = Пакет.Операторы.Получить(0);
			
			Источник = Оператор.Источники.Добавить("ТаблицаПолучателейОтчета", "ТаблицаПолучателейОтчета");
			ТипПолучателей = ПараметрыПолучателей.ТипПолучателейРассылки.КлючОбъектаМетаданных.Получить();
			Если ТипПолучателей = Тип("СправочникСсылка.Пользователи") Тогда
				Источник.Соединения.Добавить("Получатели", "Получатели.Получатель = ТаблицаПолучателейОтчета.Получатель");
			Иначе
				Источник.Соединения.Добавить("Получатели", "Получатели.Ссылка = ТаблицаПолучателейОтчета.Получатель");
			КонецЕсли;
			
			Источник.Соединения[0].ТипСоединения =  ТипСоединенияСхемыЗапроса.Внутреннее;
			
			Запрос.Текст = Схема.ПолучитьТекстЗапроса();
			
			Запрос.УстановитьПараметр("ТаблицаПолучателейОтчета", тзПолучателей);
			
		КонецЕсли;
		
	КонецЕсли;
	
	
КонецПроцедуры

Код функции СформироватьСписокПолучателейРассылки() модуля объекта отчета:

Функция СформироватьСписокПолучателейРассылки() Экспорт
	
	СхемаСКД = ПолучитьМакет("ОтборПолучателейРассылки");
	
	КомпоновщикНастроекДанныхОтчета = Новый КомпоновщикНастроекКомпоновкиДанных;
	КомпоновщикНастроекДанныхОтчета.Инициализировать(Новый ИсточникДоступныхНастроекКомпоновкиДанных(СхемаСКД));
	КомпоновщикНастроекДанныхОтчета.ЗагрузитьНастройки(СхемаСКД.НастройкиПоУмолчанию);
	
	НастройкиПараметрыДанных = КомпоновщикНастроекДанныхОтчета.Настройки.ПараметрыДанных;
	НастройкиОтбор = КомпоновщикНастроекДанныхОтчета.Настройки.Отбор;
	
	НастройкиОтбораПолучателей = КомпоновщикНастроек.ПользовательскиеНастройки;
	
    // переносим пользовательские настройки формируемого отчета в настройки СКД ОтборПолучателейРассылки
	Для каждого ЭлементНастройки из НастройкиОтбораПолучателей.Элементы Цикл
		
		Если ТипЗнч(ЭлементНастройки)=Тип("ЗначениеПараметраНастроекКомпоновкиДанных") тогда
			Для каждого ЭлементТекущейНастройки из НастройкиПараметрыДанных.Элементы цикл
				Если СокрЛП(ЭлементНастройки.Параметр)=СокрЛП(ЭлементТекущейНастройки.Параметр) тогда
					ЭлементТекущейНастройки.Использование = ЭлементНастройки.Использование;
					ЭлементТекущейНастройки.Значение      = ЭлементНастройки.Значение;
					Прервать;
				КонецЕсли;
			КонецЦикла;    
		КонецЕсли;    		
		
		Если ТипЗнч(ЭлементНастройки)=Тип("ЭлементОтбораКомпоновкиДанных") тогда
			
			ЭлементОтбораКД = ОтчетыКлиентСервер.ПолучитьОбъектПоПользовательскомуИдентификатору(КомпоновщикНастроек.Настройки, ЭлементНастройки.ИдентификаторПользовательскойНастройки);
			
			Для каждого ЭлементОтбора из НастройкиОтбор.Элементы Цикл
				Если СокрЛП(ЭлементОтбора.ЛевоеЗначение) = СокрЛП(ЭлементОтбораКД.ЛевоеЗначение) Тогда
					ЭлементОтбора.Использование = ЭлементНастройки.Использование;
					ЭлементОтбора.ВидСравнения = ЭлементНастройки.ВидСравнения;
					ЭлементОтбора.ПравоеЗначение = ЭлементНастройки.ПравоеЗначение;
					Прервать;
				КонецЕсли;
				
			КонецЦикла;
			
		КонецЕсли;
		
	КонецЦикла;
	
	КомпоновщикМакета = Новый КомпоновщикМакетаКомпоновкиДанных;
	Макет = КомпоновщикМакета.Выполнить(СхемаСКД, КомпоновщикНастроекДанныхОтчета.ПолучитьНастройки(),,,Тип("ГенераторМакетаКомпоновкиДанныхДляКоллекцииЗначений"));
	
	ПроцессорКомпоновки = Новый ПроцессорКомпоновкиДанных;
	ПроцессорКомпоновки.Инициализировать(Макет);	
	
	ПроцессорВывода = Новый ПроцессорВыводаРезультатаКомпоновкиДанныхВКоллекциюЗначений;
	тзПолучателей = Новый ТаблицаЗначений;
	ПроцессорВывода.УстановитьОбъект(тзПолучателей);
	
	ПроцессорВывода.Вывести(ПроцессорКомпоновки);	
	
	Возврат тзПолучателей;
	
КонецФункции

В качестве примера к публикации прикладывается расширение, реализующее описанный механизм для отчета _ДемоФайлы из демонстрационной базы БСП.

До подключения расширения список получателей рассылки выглядел таким образом (выводятся все пользователи):

После подключения расширения выводятся только пользователи, по которым будут сформированы не пустые отчеты:

 

Дополнительная информация

Тестирование подсистемы проводилось на версии платформы 8.3.21.1302 (режим совместимости конфигурации 8.3.14). При разработке использовалась Библиотека стандартных подсистем версии 3.1.7.

рассылка отчетов персонализированная оптимизация БСП

См. также

Взаиморасчеты Email рассылки Акт сверки Бухгалтер Пользователь Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Бухгалтерский учет Платные (руб)

Внешняя обработка для Бухгалтерии 3.0 - позволяет автоматически формировать документы «Акт сверки расчетов» с контрагентами за выбранный период с последующей фоновой отправкой на почту контрагента.

3000 руб.

25.11.2020    24997    257    8    

221

БСП (Библиотека стандартных подсистем) Программист Платные (руб)

Синтакс-помощник БСП - cправочник по библиотекам стандартных подсистем и электронных документов. В состав справочника входит описание экспортных процедур и функций, размещенных в областях кода ПрограммныйИнтерфейс БСП и БЭД.

1800 руб.

21.11.2024    3642    16    15    

18

Взаиморасчеты Email рассылки Акт сверки Бухгалтер Пользователь Платформа 1С v8.3 1С:Управление нашей фирмой 1.6 1С:Управление нашей фирмой 3.0 Бухгалтерский учет Управленческий учет Платные (руб)

Создать и отправить 1000 Актов серки контрагентам за 5 мин ?! Легко! Разработано для конфигурации УНФ Массовое создание и рассылка Актов сверки в три клика.

6000 руб.

13.01.2022    10914    8    13    

13

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

Решение для массовой рассылки печатных форм (в том числе и дополнительных) любых документов, и произвольных файлов. Рассылка возможна посредством электронной почты, Telegram и файловой системы. Рассылка пакета документов. Добавление факсимильных печати и подписи. Произвольные шаблоны HTML/Simple text с автозаполнением любыми полями документа. Любые форматы файлов. Упаковка вложений в архив. Транслитерация имен файлов. Разбиение рассылки на произвольные порции. Обход спам-фильтров. Журналирование рассылок.

4920 руб.

30.06.2022    11349    73    98    

35

Взаиморасчеты Email рассылки Бухгалтер Пользователь Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Бухгалтерский учет Платные (руб)

Обработка позволяет автоматически сформировать акты сверок на почту контрагентов (почта берется из контактных данных контрагента). При формировании акта сверки формируется подпись с указанием контактов для связи с бухгалтерией нашей организации (формируется исходя из контактов из карточки организации). Присутствует возможность ручного редактирования электронной почты контрагента для отправки. Отправка осуществляется с системной записи электронной почты. В случае, если у контрагента нет адреса электронной почты, эти контрагенты будут выведены в отдельной табличной части. Это очень удобно, так как сразу наглядно виден список контрагентов, которым невозможно отправить акты сверок!

7080 руб.

11.05.2021    9729    6    1    

6
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Serg2000mr 760 07.06.24 23:39 Сейчас в теме
Отличное решение. Только нужно еще учесть, что есть отборы самой рассылки, и их тоже нужно применять.
Прикрепленные файлы:
2. Serg2000mr 760 08.06.24 08:29 Сейчас в теме
(1) За исключением отбора по полю со значением [Получатель], ведь нужен весь список получателей.
Оставьте свое сообщение