Шаблон внешней печатной формы в формате office open XML (Microsoft Word, OpenOffice.org Writer, Google Docs и др.)

11.07.20

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

В данной публикации я хочу поделиться шаблоном внешней печатной формы в формате office open XML (Microsoft Word, OpenOffice.org Writer, Google Docs и др.) с использованием БСП.

Скачать файл

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

Наименование По подписке [?] Купить один файл
Шаблон внешней печатной формы office open XML
.epf 17,14Kb ver:3.0.3.223
67
67 Скачать (1 SM) Купить за 1 850 руб.

С помощью БСП (библиотека стандартных подсистем) можно реализовать заполнение печатной формы в формате office open XML. Для этого необходимо особым образом разметить макет печатной формы. Макет можно подготовить в любом приложении, которое работает со стандартном office open XML (Microsoft Word, OpenOffice.org Writer, Google Docs и др.). Области макета выделяются с помощью разделителей специального вида:

{v8 Область.<ИмяОбласти>}

...

{/v8 Область.<ИмяОбласти>}

Каждая область может содержать параметры:

{v8 <ИмяПараметра>}

Подробное описание создания печатной формы в формате office open XML можно прочитать в документации к БСП. Также в демо базе БСП есть готовые примеры печатных форм в формате office open XML (ссылка на скачивание БСП).

Шаблон печатной формы:

 
 Сведения о внешней обработке
 
 Печать
 
 Служебные процедуры и функции
 
 Весь код модуля обработки

 

#Область СведенияОВнешнейОбработке

Функция СведенияОВнешнейОбработке() Экспорт
	
    ПараметрыРегистрации = ДополнительныеОтчетыИОбработки.СведенияОВнешнейОбработке("3.0.3.223");
	ПараметрыРегистрации.Вид = ДополнительныеОтчетыИОбработкиКлиентСервер.ВидОбработкиПечатнаяФорма();
    ПараметрыРегистрации.Версия = "3.0.3.223";
	ПараметрыРегистрации.Наименование = НСтр("ru ='Печатная форма (формат Office Open XML)'");
	ПараметрыРегистрации.Информация = НСтр("ru ='Печатная форма (формат Office Open XML)'");
	ПараметрыРегистрации.БезопасныйРежим = Ложь;
	
    // Определение объектов, к которым подключается эта обработка.
	
	МассивНазначений = Новый Массив;
	
	ПараметрыРегистрации.Назначение = МассивНазначений;
	
    // Добавление команд.
    НоваяКоманда = ПараметрыРегистрации.Команды.Добавить();
    НоваяКоманда.Представление = НСтр("ru ='Печатная форма (формат Office Open XML)'");
    НоваяКоманда.Идентификатор = "ПечатнаяФормаOfficeOpenXML";
    НоваяКоманда.Использование = ДополнительныеОтчетыИОбработкиКлиентСервер.ТипКомандыВызовСерверногоМетода();
    НоваяКоманда.Модификатор = "";
		
    Возврат ПараметрыРегистрации;
	
КонецФункции

#КонецОбласти

#Область Печать

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

функция НапечататьДокументOfficeOpenXML(Ссылка, ДанныеМакетов, ИмяМакета)
	
	//Тестовые данные, могут быть получены ранее или в этой функции
	ДанныеОбъекта = Новый Структура;
	ДанныеОбъекта.Вставить("Товары",Новый Массив);
	ДанныеОбъекта.Товары.Добавить(Новый Структура("Номенклатура,Количество,Цена,Сумма","Номенклатура тест", "10", "1000", "10000"));
	ДанныеОбъекта.Вставить("Номер", "12345");
	ДанныеОбъекта.Вставить("Организация", "ООО НАША ОРГАНИЗАЦИЯ");
	ДанныеОбъекта.Вставить("Контрагент", "ООО КОНТРАГЕНТ");
	
	ТипМакета = ДанныеМакетов.ТипыМакетов[ИмяМакета];
	ДвоичныеДанныеМакета = ДанныеМакетов.ДвоичныеДанныеМакетов;
	Области = ДанныеМакетов.ОписаниеОбластей;
	
	Макет = УправлениеПечатью.ИнициализироватьМакетОфисногоДокумента(ДвоичныеДанныеМакета[ИмяМакета],ТипМакета,
	ИмяМакета);
	
	Если Макет = Неопределено Тогда
		Возврат "";
	КонецЕсли;
	
	ЗакрытьОкноПечатнойформы = Ложь;
	
	Попытка
		
		ПечатнаяФорма = УправлениеПечатью.ИнициализироватьПечатнуюФорму(ТипМакета, Макет.НастройкиСтраницыМакета,
		Макет);
		АдресХранилищаПечатнойФормы = "";
		
		Если ПечатнаяФорма = Неопределено Тогда
			УправлениеПечатью.ОчиститьСсылки(Макет);
			Возврат "";
		КонецЕсли;
		
		// Вывод верхней части документа - обычная область с параметрами.
		Область = УправлениеПечатью.ОбластьМакета(Макет, Области[ИмяМакета]["Шапка"]);
		УправлениеПечатью.ПрисоединитьОбластьИЗаполнитьПараметры(ПечатнаяФорма, Область, ДанныеОбъекта);
		
		// Вывод коллекции данных из информационной базы в виде таблицы.
		Область = УправлениеПечатью.ОбластьМакета(Макет, Области[ИмяМакета]["Товары"]);
		УправлениеПечатью.ПрисоединитьОбласть(ПечатнаяФорма, Область, Ложь);
		Область = УправлениеПечатью.ОбластьМакета(Макет, Области[ИмяМакета]["СтрокаТаблицаТовары"]);
		УправлениеПечатью.ПрисоединитьИЗаполнитьКоллекцию(ПечатнаяФорма, Область, ДанныеОбъекта.Товары);
		
		АдресХранилищаПечатнойФормы = УправлениеПечатью.СформироватьДокумент(ПечатнаяФорма);
		
	Исключение
		ОбщегоНазначения.СообщитьПользователю(КраткоеПредставлениеОшибки(ИнформацияОбОшибке()));
		ЗакрытьОкноПечатнойФормы = Истина;
		Возврат "";
	КонецПопытки;
	
	УправлениеПечатью.ОчиститьСсылки(ПечатнаяФорма, ЗакрытьОкноПечатнойФормы);
	УправлениеПечатью.ОчиститьСсылки(Макет);
	
	Возврат АдресХранилищаПечатнойФормы;
	
Конецфункции

#КонецОбласти

#Область СлужебныеПроцедурыИФункции

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

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

функция ОписаниеОбластейМакетаОфисногоДокумента()
	
	ОписаниеОбластей = Новый Структура;
	
	УправлениеПечатью.ДобавитьОписаниеОбласти(ОписаниеОбластей, "Шапка", "Общая");
	УправлениеПечатью.ДобавитьОписаниеОбласти(ОписаниеОбластей, "Товары", "СтрокаТаблицы");
	УправлениеПечатью.ДобавитьОписаниеОбласти(ОписаниеОбластей, "СтрокаТаблицаТовары", "СтрокаТаблицы");
	
	Возврат ОписаниеОбластей;
	
Конецфункции

#КонецОбласти

 

 

Внешний вид печатной формы из шаблона:

Данный шаблон разрабатывался и тестировался на БСП версии 3.0.3.223.

внешняя печатная форма word xml office open ворд

См. также

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

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

12000 руб.

02.09.2020    169302    937    403    

905

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

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

8400 руб.

20.08.2024    12613    99    42    

101

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

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

9360 руб.

17.05.2024    26538    90    48    

134

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

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

22200 руб.

06.10.2023    16830    41    15    

75

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

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

15000 руб.

10.11.2023    11397    40    27    

66

SALE! %

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

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

4800 3840 руб.

14.01.2013    190552    1150    0    

918

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

Разработка Конструктор автоматизированных рабочих мест "Конструктор АРМ" реализована в виде расширения и является универсальным инструментом для создания АРМ любой сложности в пользовательском режиме.

3600 руб.

27.12.2024    779    2    0    

4

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

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

5000 руб.

07.02.2018    103934    244    100    

306
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. mariya.mary.00 02.02.22 17:55 Сейчас в теме
Добрый день!

Подскажите, пожалуйста,как можно получить путь, куда сохраняется сформированный файл печатной формы?
Использовала Ваш код,всё прекрасно формируется,спасибо!, но есть необходимость пересохранять файл в другой формат, например word в pdf.
Оставьте свое сообщение