Программное создание таблицы в WORD с использованием разметки Office Open XML. Через сервер с использованием БСП

09.02.24

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

Пример как можно программно создать таблицу в ворде на основе Табличного документа. С использованием разметки Office Open XML на сервере с использованием функций БСП для печати.

Скачать исходный код

Наименование Файл Версия Размер
Таблица программно в WORD
.epf 21,67Kb
9
.epf 21,67Kb 9 Скачать

Создаем макет, где вставляем тег, который далее заместим на сгенерированную xml разметку с таблицей.

 

Далее после кода, где определяется область с таблицей

Область = УправлениеПечатью.ОбластьМакета(Макет, Области[ИмяМакета].Документ); 

Добавляем следующий код. 

	ТекстОбласти = Область.Текст;
		ИмяТаблицы = "Таблица"; 
		НомерТаблицы = 1;
		
		Таблица = ЗначениеИзСтрокиВнутр(ТаблицаСтрока);				
		НомерТаблицы = НомерТаблицы + 1;
		
		СтрокаПоиска = "{v8 " + ИмяТаблицы + "}"; 
		НачалоТаблицы = СтрНайти(ТекстОбласти, СтрокаПоиска);    
		
		Если НачалоТаблицы = 0 Тогда
			
			Возврат "";	
			
		КонецЕсли;  
		
		КонецПараграфа = СтрНайти(ТекстОбласти, "</w:p>",, НачалоТаблицы);  
		НачалоПараграфа = СтрНайти(ТекстОбласти, "<w:p ", НаправлениеПоиска.СКонца, НачалоТаблицы);
		СтрокаЗамены = Сред(ТекстОбласти, НачалоПараграфа, КонецПараграфа - НачалоПараграфа +6 );
		//СтрокаБезТегаТаблица = СтрЗаменить(СтрокаЗамены, СтрокаПоиска, "");
		ТабДокумент = Таблица;	
		ПоследняяСтрока = ТабДокумент.ВысотаТаблицы;  
		ПоследняяКолонка = ТабДокумент.ШиринаТаблицы;   
		
		ТаблицаХМЛ = "";  
		ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, ("<w:tbl>"));  // начало таблицы
		ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, ("<w:tblPr>"));  // начало свойств
		ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, ("<w:tblW w:w=""0"" w:type=""auto""/>"));  // начало свойств
		
		ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, ("<w:tblBorders>"));  // Границы   
		ТекстГраница = "<w:%1 w:val=""single"" w:sz=""4"" w:space=""0"" w:color=""auto""/>";
		ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, СтрШаблон(ТекстГраница, "top")); 
		ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, СтрШаблон(ТекстГраница, "left")); 
		ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, СтрШаблон(ТекстГраница, "bottom")); 
		ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, СтрШаблон(ТекстГраница, "right")); 
		ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, СтрШаблон(ТекстГраница, "insideH")); 
		ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, СтрШаблон(ТекстГраница, "insideV")); 
		ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, ("</w:tblBorders>")); 
		
		ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, ("</w:tblPr>"));
		
		// перебор столбцов
		НомерСтолбца = 1;
		Пока НомерСтолбца <= ПоследняяКолонка Цикл   
			Ячейка = ТабДокумент.Область("R1C" + НомерСтолбца); 
			НомерСтолбца = НомерСтолбца + 1;  			
		КонецЦикла;

		НомерСтр = 1; 
		Пока НомерСтр <= ПоследняяСтрока Цикл
			ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, "<w:tr>"); //начало описание строки
			Для Счетчик = 1 По НомерСтолбца - 1 Цикл
				
				Ячейка = ТабДокумент.Область("R" + Строка(НомерСтр) + "C"+Счетчик);  
				
				ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, "<w:tc>"); //начало ячейки
				
				Если НомерСтр = 1 Тогда
					ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, "<w:tcPr><w:tcW w:w=""0"" w:type=""auto""/><w:shd w:val=""clear"" w:color=""auto"" w:fill=""366091""/></w:tcPr>");
				Иначе	
					ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, "<w:tcPr><w:tcW w:w=""0"" w:type=""auto""/></w:tcPr>");
				КонецЕсли;   
				
				ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, "<w:p>");
				ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, "<w:r>"); 
				Если НомерСтр = 1  Тогда
					ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, "<w:rPr><w:color w:val=""#FFFFFF"" /></w:rPr>)");	
				КонецЕсли;
				ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, "<w:t>");
				
				ТекстЯчейки = Ячейка.Текст;
				
				Если СтрНайти(ТекстЯчейки, ">") > 0 Тогда
					ТекстЯчейки = СтрЗаменить(ТекстЯчейки, ">", "&gt;")	
				КонецЕсли; 
				
				Если СтрНайти(ТекстЯчейки, "<") > 0 Тогда
					ТекстЯчейки = СтрЗаменить(ТекстЯчейки, "<", "&lt;")	
				КонецЕсли; 
								
				ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, ТекстЯчейки);
				
				ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, "</w:t>");
				ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, "</w:r>");
				ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, "</w:p>");
				ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, "</w:tc>"); // 
				
			КонецЦикла;  
			
			НомерСтр = НомерСтр + 1; 
			ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, "</w:tr>");
			
		КонецЦикла;  
		
		ТаблицаХМЛ = ДобавитьТекст(ТаблицаХМЛ, ("</w:tbl>"));
		
		ТекстОбласти = СтрЗаменить(ТекстОбласти, СтрокаЗамены, ТаблицаХМЛ);
		
		
		Область.Текст = ТекстОбласти;
		
		УправлениеПечатью.ПрисоединитьОбластьИЗаполнитьПараметры(ПечатнаяФорма, Область, ДанныеОбъекта);

В коде идет раскрашивание первой строки таблицы, в итоге получаем на печать следующее.

Если надо что-то новое добавить в таблицу, пользуемся разметкой Office Open xml тут - http://datypic.com/sc/ooxml/ss.html

А вот тут есть подробнее про таблицы - http://officeopenxml.com/WPtable.php

Тестировалось на "Библиотека стандартных подсистем", редакция 3.1 (3.1.9.104).

Проверено на следующих конфигурациях и релизах:

  • 1С:ERP Управление предприятием 2, релизы 2.5.14.74

См. также

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

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

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

10000 руб.

02.09.2020    129664    700    390    

751

Infostart PrintWizard - создание и редактирование печатных форм в 1С 8.3

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

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

18000 руб.

06.10.2023    9053    25    6    

49

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

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

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

10000 руб.

10.11.2023    5228    14    2    

39

OneDebugger - инструмент для отладки кода без использования режима конфигуратора

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

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

5400 руб.

17.05.2024    4160    3    12    

28

Бустер Конвертации данных 3 (Infostart Toolkit)

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

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

15000 руб.

07.10.2021    15344    3    12    

38

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

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

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

5000 руб.

07.02.2018    100254    240    97    

299

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

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

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

2040 руб.

27.12.2017    28650    4    10    

17

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

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

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

3000 руб.

27.08.2019    18781    6    8    

41
Отзывы
2. Wilka 100 12.02.24 10:41 Сейчас в теме
(1)да, но в данном случае можно сделать любую таблицу и вывести ее. А в варианте бсп нужно точно знать количество столбцов и шапка делается фиксировано. Данное решение, только для из-за чего-то динамически меняющихся таблиц, которые надо вывести.
Aleskey_K; +1 Ответить
1. Aleskey_K 35 12.02.24 08:27 Сейчас в теме
Спасибо за публикацию.
Можно сделать проще: настроить таблицу в нужном стиле и размерах, а затем построчно вывести методами БСП.
Прикрепленные файлы:
Остальные комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Aleskey_K 35 12.02.24 08:27 Сейчас в теме
Спасибо за публикацию.
Можно сделать проще: настроить таблицу в нужном стиле и размерах, а затем построчно вывести методами БСП.
Прикрепленные файлы:
2. Wilka 100 12.02.24 10:41 Сейчас в теме
(1)да, но в данном случае можно сделать любую таблицу и вывести ее. А в варианте бсп нужно точно знать количество столбцов и шапка делается фиксировано. Данное решение, только для из-за чего-то динамически меняющихся таблиц, которые надо вывести.
Aleskey_K; +1 Ответить
Оставьте свое сообщение