Простой вывод табличного документа в общую форму "Печать документов", с использованием БСП

08.12.17

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

Простой вывод табличного документа из модуля формы внешней обработки, в общую форму "Печать документов", с использованием БСП. Проверялось на версии БСП 2.2.5.30 в конфигурации УТ 11.1.

Скачать файлы

Наименование Файл Версия Размер
Пример вывода табличного документа в общую форму "Печать документов"
.epf 7,50Kb
32
.epf 7,50Kb 32 Скачать

Всем доброго дня!

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

Есть несколько достаточно подробных статей на эту тему вывода в общую форму,  например, вот эта: тыц

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

Итак от слов к делу: 

  1. Создаем новую обработку и новую форму
  2.  Добавляем команду (например "Печать") создадим процедуру "Печать", которая будет выполняться при нажатии на кнопку, и перетаскиваем ее на форму.
  3. В модуле формы напишем следующий код, который и отвечает за вывод нашего табличного документа в общую форму "ПечатьДокументов": 
&НаКлиенте
Процедура Печать(Команда)
    // сформируем нужный нам табличный документ
    ТабДок = СформироватьТабДок();
    
    // создадим коллекцию печатных форм, в которую надо будет добавить нужный нам табличный документ
    КоллекцияПечатныхФорм = УправлениеПечатьюКлиент.НоваяКоллекцияПечатныхФорм("МакетТест");    
    // Добавляем в коллекцию (тип массив) сформированный Табличный документ
    КоллекцияПечатныхФорм[0].ТабличныйДокумент = ТабДок; 
    // если требуется устанавливаем параметры печати
    КоллекцияПечатныхФорм[0].Экземпляров=1;
    КоллекцияПечатныхФорм[0].СинонимМакета = "Макет тест";  // используется для формирования имени файла при сохранении из общей формы печати документов
    // .. и выводим стандартной процедурой БСП
    УправлениеПечатьюКлиент.ПечатьДокументов(КоллекцияПечатныхФорм,Неопределено,ЭтаФорма);

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

4. Вот и все.

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

общая форма печать документов

См. также

SALE! 20%

Infostart Toolkit: Инструменты разработчика 1С 8.3 на управляемых формах

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

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

13000 10400 руб.

02.09.2020    122171    670    389    

714

SALE! 25%

Infostart PrintWizard

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

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

18000 15300 руб.

06.10.2023    7294    21    6    

39

SALE! 20%

Infostart УДиФ: Управление данными и формами

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

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

10000 8000 руб.

10.11.2023    3541    11    1    

34

SALE! 30%

PowerTools

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

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

3600 2520 руб.

14.01.2013    177753    1073    0    

849

Многопоточность. Универсальный «Менеджер потоков» 2.1

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

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

5000 руб.

07.02.2018    99347    239    97    

296

[ЕХТ] Фреймворк для Расширений 1С

Инструментарий разработчика Платформа 1С v8.3 Управляемые формы Платные (руб)

"Фреймворк для Расширений 1С" это универсальное и многофункциональное решение, упрощающее разработку и поддержку создаваемых Расширений. Поставляется в виде комплекта из нескольких Расширений с открытым исходным кодом. Работает в любых Конфигурациях в режиме Управляемого приложения с режимом совместимости 8.3.12 и выше без необходимости внесения изменений в Конфигурацию.

3000 руб.

27.08.2019    18116    6    8    

39

1С HTML Шаблоны / HTML Templates

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

Быстрая и удобная обработка для работы с шаблонами HTML. Позволяет легко и быстро формировать код HTML.

2040 руб.

27.12.2017    28110    3    10    

15

Выполнение произвольного кода или запроса с параметрами через Web-сервис (замена COM-подключений)

Инструментарий разработчика Обмен между базами 1C Платформа 1С v8.3 Платные (руб)

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

2400 руб.

24.09.2019    23604    15    15    

32
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. held88 59 06.09.18 07:11 Сейчас в теме
Огромное спасибо за этот кусок кода. То что давно искал.
2. dmitry1975 335 06.09.18 14:01 Сейчас в теме
3. ivnik 581 14.10.18 21:25 Сейчас в теме
Огромное Спасибо!!! Коротко и работает!
4. InJey 02.12.18 14:47 Сейчас в теме
Спасибо! Для начинающего очень помогает!
5. Autolans 03.12.18 15:09 Сейчас в теме
6. dmitry1975 335 03.12.18 15:31 Сейчас в теме
Пожалуйста! Сам иногда обращаюсь к своей заметке :)))) Забывается то, чем постоянно не пользуешься..
7. glorry 13.12.18 09:59 Сейчас в теме
Спасибо тебе!!!! Я никак не мог сам найти, а оказывается все было так просто!!!!!
8. dmitry1975 335 15.12.18 08:34 Сейчас в теме
(7) Пожалуйста! Рад, что помогло.
9. user1118259 23.01.19 13:54 Сейчас в теме
Спасибо. То что нужно. Теперь бы разобраться с этим, а то магия какая то.
10. dmitry1975 335 23.01.19 14:50 Сейчас в теме
(9) А что именно в этом непонятно?
11. user1118259 24.01.19 08:09 Сейчас в теме
Мне не понятно как это работает. Но мне бы хотелось самому попытаться разобраться с механизмом этого кода. Сейчас я просто вставил кусок кода и пользуюсь. Я начинающий. Это моя первая печатная форма, да еще и через расширение. Так что не удивляйтесь. Это просто положительные эмоции начинающего.
12. dmitry1975 335 24.01.19 16:56 Сейчас в теме
(11) В общем-то ничего особо сложного здесь нет.
Весь нужный для вывода печатной формы функционал, обеспечивает библиотека стандартных подсистем, которая реализована разработчиками 1С для облегчения программирования стандартных задач. Поэтому приведенный в статье код и выглядит вполне компактным.

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

Один из параметров функции - это коллекция печатных форм, которая представляет собой в конечном виде массив структур, т.е. элементами массива является структура с нужными значениями.
Коллекция формируется строкой кода
КоллекцияПечатныхФорм = УправлениеПечатьюКлиент.НоваяКоллекцияПечатныхФорм("МакетТест");


После чего можно обратится к массиву по индексу и установить нужные данные, такие как табличный документ и количество экземпляров.
вот собственно и все.
Прикрепленные файлы:
user733003; +1 Ответить
13. demONx7 05.04.19 09:06 Сейчас в теме
Уф... Столько мучений, а ларчик просто открывался.

ОГРОМНЕЙШЕЕ тебе спасибо)))))
14. dmitry1975 335 05.04.19 20:04 Сейчас в теме
15. AlexeyT1978 202 29.04.19 16:01 Сейчас в теме
16. molot 285 11.06.19 13:37 Сейчас в теме
Всё гениальное просто! Спасибо! Сэкономил полчасика времени мне)
17. molot 285 11.06.19 13:57 Сейчас в теме
Чтобы заработала привязка файла к ссылке надо еще немножко дополнить:

// создадим коллекцию печатных форм, в которую надо будет добавить нужный нам табличный документ
    КоллекцияПечатныхФорм = УправлениеПечатьюКлиент.НоваяКоллекцияПечатныхФорм("СписокВодителей");
    // Добавляем в коллекцию (тип массив) сформированный Табличный документ
    КоллекцияПечатныхФорм[0].ТабличныйДокумент = ТабДок; 
	ТабДок.Область(1, , ТабДок.ВысотаТаблицы, ).Имя = "СписокВодителей";
    // если требуется устанавливаем параметры печати
    КоллекцияПечатныхФорм[0].Экземпляров = 2;
    КоллекцияПечатныхФорм[0].СинонимМакета = "Список водителей"; // используется для формирования имени файла при сохранении из общей формы печати документов
    // .. и выводим стандартной процедурой БСП
	ОбъектыПечати = Новый СписокЗначений;
	ОбъектыПечати.Добавить(ПараметрКоманды, "СписокВодителей");
    УправлениеПечатьюКлиент.ПечатьДокументов(КоллекцияПечатныхФорм, ОбъектыПечати);
Показать
agatdev_ilganas; Lapitskiy; +2 Ответить
22. mikl79 118 11.12.20 08:36 Сейчас в теме
(17), подскажите пожалуйста - что за привязка файла к ссылке?
18. user1038344 19.03.20 14:43 Сейчас в теме
Спасибо! пригодилось!
19. user886140 15.08.20 21:08 Сейчас в теме
Спасибо добрый человек! Очень помог!
20. Shilov 4 03.11.20 10:27 Сейчас в теме
Благодарю. Очень помогло сэкономить время.
21. dmitry1975 335 03.11.20 12:39 Сейчас в теме
(20)Пожалуйста! Рад, что пригодилось :)
23. ulucky 45 19.12.20 23:33 Сейчас в теме
Спасибо, очень помогло.
Придется учить БСП ((
24. dmitry1975 335 20.12.20 02:50 Сейчас в теме
(23)Пожалуйста! А БСП действительно нужно учить :)
25. user1497064 14.07.21 23:51 Сейчас в теме
Огромное СПАСИБО !!! Вся головушку изломал, а ларчик просто открывался :) !!!
26. dmitry1975 335 16.07.21 13:26 Сейчас в теме
(25) Рад что пригодилось :)
27. Maindevice 06.08.21 08:50 Сейчас в теме
Эх, а попадись эта заметка мне на глаза всего год назад, то количество костылей в моём коде сократилось бы на порядок. ХD
Огромное спасибо!
28. ssfedkin 6 21.03.22 19:03 Сейчас в теме
29. dmitry1975 335 21.03.22 19:08 Сейчас в теме
(27), (28) Рад что пригодилось!
30. psa247 17 31.01.23 07:59 Сейчас в теме
31. dmitry1975 335 31.01.23 08:00 Сейчас в теме
Рад, что пригодилось :)
32. sokol_6630 3 05.07.23 15:19 Сейчас в теме
33. Dm109 11.07.23 10:27 Сейчас в теме
Громаднейшее спс. Коротко, ясно и самое смешное - РАБОТАЕТ!
34. dmitry1975 335 11.07.23 10:28 Сейчас в теме
(33) Не за что! Действительно смешно :)))))))))))))
35. neyasytyf 14.11.23 16:04 Сейчас в теме
Спасибо) По Вашему решению нашел как сделано в типовых.
ТабличныйДокумент = ПолучитьИзВременногоХранилища(АдресХранилища);
		
	МодульУправлениеПечатьюКлиент = ОбщегоНазначенияКлиент.ОбщийМодуль("УправлениеПечатьюКлиент");
	ИдентификаторПечатнойФормы = "Печать";
		
	КоллекцияПечатныхФорм = МодульУправлениеПечатьюКлиент.НоваяКоллекцияПечатныхФорм(ИдентификаторПечатнойФормы);
	ПечатнаяФорма = МодульУправлениеПечатьюКлиент.ОписаниеПечатнойФормы(КоллекцияПечатныхФорм, ИдентификаторПечатнойФормы);
	ПечатнаяФорма.СинонимМакета = НСтр("ru = 'Печать'");
	ПечатнаяФорма.ТабличныйДокумент = ТабличныйДокумент;
	
	МодульУправлениеПечатьюКлиент.ПечатьДокументов(КоллекцияПечатныхФорм);
Показать
extralook; dmitry1975; +2 Ответить
36. psa247 17 26.02.24 17:38 Сейчас в теме
Круто, без лишних заморочек, спасибо!
37. apx_egor 27.02.24 11:49 Сейчас в теме
38. dmitry1975 335 27.02.24 13:10 Сейчас в теме
Я рад, что даже спустя столько времени с момента написания этой заметки, кому-то это помогает :)
39. user731275 25.03.24 17:42 Сейчас в теме
Тоже наткнулся на заметку и реально помогло. Автору респект.
Оставьте свое сообщение