Пример формирования внешнего отчета программно и в фоновом режиме

28.08.18

Разработка - Инструментарий разработчика

Пример формирования внешнего отчета программно и фоновом режиме на управляемых формах, также можно подключить его как внешний отчет.

Скачать файл

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

Наименование По подписке [?] Купить один файл
Пример внешнего отчета:
.erf 13,18Kb
96
96 Скачать (1 SM) Купить за 1 850 руб.

Этот отчет (ОСВ) был сделан для примера, так сказать показать наглядно на практике, какие есть возможности формирования отчета в платформе 1С.

На форме присутствуют 4 кнопки, которые формируют отчет тем или иным способом.

1. Сформировать - Отчет будет формироваться штатным образом, то есть стандартная команда формы "Сформировать".

2. Сформировать (программно) - Отчет будет формироваться программным образом вызывая процедуру "СформироватьОтчет" в модуле объекта. Передавая в качестве параметров "СхемуКомпоновкиДанных" и АдресХранилища куда будет помещатся результат процедуры. 

3. Сформировать (длительные  операции в фоне) - Отчет формируется по средствам БСП используя модули "ДлительныеОперации.ЗапуститьВыполнениеВФоне" и "ДополнительныеОтчетыИОбработки.ВыполнитьКоманду". Также как и во 2-ом способе основной процедурой обработчиком будет являтся  "СформироватьОтчет" в модуле объекта. Этот способ формирования я считаю самой сложной (по крайней мере для меня), так как в свое время, чтобы релизовать этот способ у меня ушло много времени. И собственно порадило эту публикация, чтобы другие тоже не теряли время. Главным услувием является добавления отчета как внешний отчет в режиме предприятия в подсистему "ДополнительныеОтчетыИОбработки".

4. Сформировать отчет (режим компоновки в фоне) -  Отчет формируется также как и первый способ, исключение лишь в том что задается режим компоновки как "РежимКомпоновкиРезультат.Фоновый".

Отчет тестировался на версия БСП - 2.2.5.32, который был в конфигурации Бухгалтерия для Казахстана ред. 3.0 релиз 3.0.9.35. Отчет можно в дальнейшем использовать для разработок новых отчетов, без добавления его в конфигурацию как объект отчет. Тем самым облегчая дальнейшее сопровождение конфигурации.

В отчете достаточно изменить Запрос СКД, в коде КлючТекущегоВарианта ну и везде где есть упоминание про "Пример отчета".

Ниже приведу весь код отчета 

 
Модуль формы отчета:
 
Модуль объекта:

 

Внешний отчеты и обработки ДополнительныеОтчетыИОбработки СКД Выполенение в фоне.

См. также

SALE! 15%

Инструментарий разработчика Роли и права Запросы СКД Программист Платформа 1С v8.3 Управляемые формы Запросы Система компоновки данных Конфигурации 1cv8 Платные (руб)

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравнение объектов, Все функции, Подписки на события и др. Редактор запросов и кода с раскраской и контекстной подсказкой. Доработанный конструктор запросов тонкого клиента. Продукт хорошо оптимизирован и обладает самым широким функционалом среди всех инструментов, представленных на рынке.

10000 руб.

02.09.2020    159721    876    399    

862

SALE! 15%

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

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP и т.д.). Поддерживаются управляемые и обычные формы. Может выполнять свертку сразу нескольких баз данных и выполнять их автоматически без непосредственного участия пользователя.

8400 7140 руб.

20.08.2024    7903    59    23    

69

Инструментарий разработчика Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки.

9360 руб.

17.05.2024    23511    68    45    

117

SALE! 15%

Инструменты администратора БД Инструментарий разработчика Роли и права Программист Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

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

10000 8500 руб.

10.11.2023    10476    36    25    

61

SALE! 15%

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

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

22200 19980 руб.

06.10.2023    15444    35    7    

70

SALE! 35%

Инструментарий разработчика Инструменты администратора БД Системный администратор Программист Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Россия Платные (руб)

Универсальный инструмент программиста для администрирования конфигураций. Сборник наиболее часто используемых обработок под единым интерфейсом.

4800 3120 руб.

14.01.2013    188085    1140    0    

912

SALE! 15%

Инструментарий разработчика Программист 8.3.14 1С:Конвертация данных Россия Платные (руб)

Расширение для конфигурации “Конвертация данных 3”. Добавляет подсветку синтаксиса, детальную контекстную подсказку, глобальный поиск по коду.

15000 12750 руб.

07.10.2021    17319    6    32    

42

Инструментарий разработчика Программист Платные (руб)

Менеджер конфигураций 1С — альтернативный стартер информационных баз 1С:Предприятие.

1800 руб.

21.02.2023    7725    8    35    

23
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. shura_k 15.11.17 10:58 Сейчас в теме
пробую ваш обработку, для меня так же важно запустить отчет в фоне.
отчет сам формируется нормально, и штатными средствами и вашей процедурой СформироватьОтчетПрограммноНаСервере.
но вот с фоновом формированием - проблема.
ничего не возвращается из Временного Хранилища!
помогите пожалуйста разобраться...

Разобрался - проблемы была в Параметры.ДополнительнаяОбработкаСсылк
2. Bakytzhan_777 62 15.11.17 11:59 Сейчас в теме
(1)Рад что разобрались). Я тоже с этим сталкивался, многие часы отладки таки не дали ответа, почему ссылка пустая. Пришлось самому присваивать ссылку в "Параметры.ДополнительнаяОбработкаСсылка".
3. shura_k 15.11.17 13:10 Сейчас в теме
но в обработке есть реально две ошибки:
1. НоваяКоманда.Идентификатор = "СформироватьОтчет";
НоваяКоманда.Использование = ДополнительныеОтчетыИОбработкиКлиентСервер.ТипКомандыВызовСерверногоМетода();
у вас изначально вариант - открытиеформы, а надо вызовсерверногометода.
У вас же даже Процедура ВыполнитьКоманду для этого уже была.
2. ДлительныеОперацииКлиент.ИнициализироватьПараметрыОбработчикаОжидания(ПараметрыОбработчикаОжидания);
ТекущийИнтервал = ПараметрыОбработчикаОжидания.ТекущийИнтервал;
ПодключитьОбработчикОжидания("Подключаемый_ПроверитьВыполнениеЗадания",ТекущийИнтервал, Истина);
надо инициализировать ПараметрыОбработчикаОжидания, иначе потом в процедуре Подключаемый_ПроверитьВыполнениеЗадания будет ошибка на ТекущийИнтервал
4. Bakytzhan_777 62 15.11.17 17:00 Сейчас в теме
(3)
1. НоваяКоманда.Идентификатор = "СформироватьОтчет";
НоваяКоманда.Использование = ДополнительныеОтчетыИОбработкиКлиентСервер.ТипКомандыВызовСерверногоМетода();
у вас изначально вариант - открытиеформы, а надо вызовсерверногометода.

Если ставить "ТипКомандыВызовСерверногоМетода()" вместо "ТипКомандыОткрытиеФормы()" то форма не откроется и запуститься сразу команда по идентификатору "СформироватьОтчет".
2. ДлительныеОперацииКлиент.ИнициализироватьПараметрыОбработчикаОжидания(ПараметрыОбработчикаОжидания);
ТекущийИнтервал = ПараметрыОбработчикаОжидания.ТекущийИнтервал;
ПодключитьОбработчикОжидания("Подключаемый_ПроверитьВыполнениеЗадания",ТекущийИнтервал, Истина);
надо инициализировать ПараметрыОбработчикаОжидания, иначе потом в процедуре Подключаемый_ПроверитьВыполнениеЗадания будет ошибка на ТекущийИнтервал
Здесь все поправил.
Спасибо вам за замечания.
Mikhail-Kobtsev; +1 Ответить
9. Mikhail-Kobtsev 27.08.18 16:57 Сейчас в теме
(3)
ыОбработчикаОжидания.ТекущийИ


подскажи в каком именно моменте необходимо инициализация ПараметрыОбработчикаОжидания ?
10. Bakytzhan_777 62 28.08.18 07:02 Сейчас в теме
(9) В типовых инициализируют при открытии формы. Я сделал в команде "СформироватьОтчетВФонеДлительныеОперации".
Mikhail-Kobtsev; +1 Ответить
5. shura_k 15.11.17 17:43 Сейчас в теме
Если ставить "ТипКомандыВызовСерверногоМетода()" вместо "ТипКомандыОткрытиеФормы()" то форма не откроется и запуститься сразу команда по идентификатору "СформироватьОтчет".

да, тоже до этого дошел.
в итоге сделал две команды: одну на открытие формы другую на ВызовСерверногоМетода.
потому как без первого - реально форма не открывается, а без второго не работает сформировать отчет в фоне.
я в процедуре формирования еще запихиваю тз во внешние данные.
6. cdromscsi 22.12.17 11:16 Сейчас в теме
Спасибо. Очень помог пример кода для пункта 3: Сформировать (длительные операции в фоне). Все работает.
7. Bakytzhan_777 62 19.01.18 20:35 Сейчас в теме
(6) Рад что помогла публикация)
8. MKassatkin 27.04.18 11:45 Сейчас в теме
Хороший пример! Пригодилось, спасибо!
11. Mikhail-Kobtsev 28.08.18 14:36 Сейчас в теме
спасибо автору за статью и еще за оперативный ответ :), давно хотел юзать отчеты через бсп в фоне.
12. Margo462 500 03.11.20 12:09 Сейчас в теме
Через фоновую компоновку делаю с внешним набором данных и появляется ошибка с ненайденной таблицей, а программно работает
Оставьте свое сообщение