Шаблон внешней печатной формы в формате 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 ворд

См. также

SALE! 15%

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

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

10000 руб.

02.09.2020    159425    872    399    

861

SALE! 15%

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

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

8400 7140 руб.

20.08.2024    7770    55    22    

66

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

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

9360 руб.

17.05.2024    23435    68    45    

117

SALE! 15%

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

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

10000 8500 руб.

10.11.2023    10425    36    22    

61

SALE! 15%

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

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

22200 19980 руб.

06.10.2023    15399    35    7    

70

SALE! 35%

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

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

4800 3120 руб.

14.01.2013    187984    1138    0    

912

SALE! 15%

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

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

15000 12750 руб.

07.10.2021    17303    6    32    

42

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

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

1800 руб.

21.02.2023    7694    8    35    

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

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