Заполнение документа Word без ComОбъект

Публикация № 590918 08.07.18

Приемы и методы разработки

word макет двоичныеданные поток потоквпамяти xpath xml документdom

Идея написать публикацию пришла после прочтения очередного рассказа о том, как файл Word заполнялся через COM-объект в клиент-серверном варианте. При этом падал Сервер 1С. Зачем в принципе использовать файлы Word как шаблоны? Ну, допустим, в организации используется некая внутренняя отчетность, выполнения в корпоративном стиле, и переделать ее на привычные табличные документы нет возможности.

Приветствую. Предлагаю вариант решения заполнения файла Word, без участия стороннего ПО, только нативные средства платформы 1С.

Известно, что файл *.docx упакованный контейнер с набором xml и медиа файлов. Но об *.doc такого сказать нельзя, это скорее бинарник. Файл docx легко распаковывается архиватором, а doc нет. А раз распаковывается и внутри у него знакомые xml, то почему бы не попробовать изменить xml программно? Необходимые средства для выполнения этой задачи платформа имеет.

Сначала попробуем разобраться как же устроен docx изнутри. Создадим новый файл Word с текстом - "Просто текст, а это МойПараметр". Затем распакуем файл и увидим следующую иерархию данных.

 

О назначении каждого из файлов хорошо написано тут. Из всех файлов для решения нашей задачи интересен только один. Адрес файла - word/document.xml. Открываем файл и видим, что содержимое не отформатировано и для визуального анализа не подойдет. Отформатировать xml онлайн можно тут или же использовать Notepad++. Дальше по ключевому слову МойПараметр находим параметр и видим примерно следующее.

<w:r>
    <w:rPr>
        <w:lang w:val="ru-RU"/>
    </w:rPr>
    <w:t>Просто текст</w:t>
</w:r>
<w:r w:rsidR="004E0307">
    <w:rPr>
        <w:lang w:val="ru-RU"/>
    </w:rPr>
    <w:t>, а это МойПараметр</w:t>
</w:r>

После небольшого анализа понятно, что текст находится в тегах t с префиксом w (стоит сказать, что все теги файла имеют этот префикс. Это пространство имен http://schemas.openxmlformats.org/wordprocessingml/2006/main). Для упрощения задачи, будем считать, что параметры шаблона всегда будем писать "верблюжьей" нотацией, потому как, если например написать вот так [Параметр1], то в xml это будет три тега <w:t>, с разными родительскими тегами <w:r>, что существенно усложнит алгоритм замены. Таким образом, чтобы программно заменить параметр на нужный текст, нужно найти тег <w:t> с текстом параметра и выполнить замену. Потом файл с замененными параметрами сохранить и упаковать в архив.

Для примера возьмем абстрактный шаблон. Добавим в него текст, параметры (помним о "верблюжьей" нотации), а также какое-либо изображение, таблицу и прочее - чтобы убедиться, что после заполнения документ будет корректно отображать содержимое.

Создадим обработку, у которой в макет с типом ДвоичныеДанные положим наш подопытный файл docx. Дальше создадим форму, команду формы и для команды элемент управления. По нажатию на кнопку передадим управление на сервер и начнем писать код. Для начала получим шаблон из макета обработки.

BinaryData = FormAttributeToValue("Object").GetTemplate("Template");

Так как тип макета ДвоичныеДанные, то и получим также двоичные данные. Дальше нужно полученные данные распаковать. Для этого воспользуемся объектом ЧтениеZipФайла. Объект инициализируется на основании объекта ПотокВПамяти, а поток в памяти создается на основании объекта БуферДвоичныхДанных, который получается из метода ПрочитатьВБуферДвоичныхДанных объекта ЧтениеДанных, который создается на основании двоичных данных, которые у нас есть.

Reader 			 = New DataReader(BinaryData);	
BinaryDataBuffer = Reader.ReadIntoBinaryDataBuffer();

Stream = New MemoryStream(BinaryDataBuffer);
	
ZipReader = New ZipFileReader(Stream);
ZipReader.ExtractAll(Dir);
ZipReader.Close();
	
Stream.Close();
Reader.Close();

Теперь прочитаем document.xml. Прочитать можно разными способами, но мы воспользуемся ПостроительDOM, который вернет объект ДокументDOM.

XMLReader = New XMLReader;
XMLReader.OpenFile(PathXMLFile);
	
Builder 	= New DOMBuilder;
DomDocument = Builder.Read(XMLReader);
XMLReader.Close();

Теперь самое интересное - поиск тегов <w:t>. Можно это сделать разными способами, вплоть до обхода ДокументDOM как дерева. Но существует способ проще. Поскольку тегов <w:t> может быть достаточно много, а нужны только те, в которых указаны наши параметры, то воспользуемся методом СоздатьВыражениеXPath объекта ДокументDOM (XPath по сути язык запросов к файлам xml).

Resolver = New DOMNamespaceResolver(DomDocument);

For Each MapElement In FillData Do
		
	XPathExpression = DomDocument.CreateXPathExpression("//w:t[contains(text(),'"+MapElement.Key+"')]", Resolver);
	XPathResult 	= XPathExpression.Evaluate(DomDocument);
		
	Node = XPathResult.IterateNext();
	While Node <> Undefined Do

		Node.TextContent = StrReplace(Node.TextContent, MapElement.Key, MapElement.Value);	
		Node = XPathResult.IterateNext();
			
	EndDo;
	
EndDo;

Поясню приведенный сниппет. Сначала создаем РазыменовательПространствИменDOM (подробнее  тут). Дальше обходим некую коллекцию данных, ключ которой это имя параметра, который подлежит замене, а значение - то, что должно быть вместо параметра. В метод СоздатьВыражениеXPath передаем запрос к xml, которым выберем все теги <w:t> файла на всех уровнях, текст которых содержит наш параметр. Вычисляем результат и обходим его, заменяя параметры нужными значениями.

Теперь сохраним ДокументDOM. Для этого используем объект ЗаписьDOM.

DOMWriter = New DOMWriter; 
XMLWriter = New XMLWriter;
XMLWriter.OpenFile(PathXMLFile); 
DOMWriter.Write(DomDocument, XMLWriter); 
XMLWriter.Close();

Осталось создать такой же контейнер, который мы распаковывали. Используем для этого ЗаписьZipФайла и уже знакомый объект ПотокВПамяти. Иерархия файлов в контейнере должна быть такой же, как и до распаковки. Для этого в метод Добавить объекта ЗаписьZipФайла передадим РежимСохраненияПутейZIP.СохранятьОтносительныеПути.

Stream = New MemoryStream;
	
ZipWriter = New ZipFileWriter(Stream,,,ZIPCompressionMethod.Deflate);
ZipWriter.Add(TempDir+"\*.*", ZIPStorePathMode.StoreRelativePath, ZIPSubDirProcessingMode.ProcessRecursively); 
ZipWriter.Write();
	
BinaryData = Stream.CloseAndGetBinaryData();

Теперь у нас есть двоичные данные, которые передаем клиентской процедуре, там их записываем в файл и открываем приложением по умолчанию для docx.

Скриншот полученной обработки

Результат работы заполнения документа Word. Шаблон до заполнения

Шаблон после заполнения

Работы проводились с Word 2010, но думаю, что на других версиях также должно работать.

Требования к платформе: версия 8.3.9+, так как  только в этой версии появилась возможность работы с потоками. Но эту проблему легко обойти, если использовать старый добрый ввод вывод через временные файлы.

Решение кроссплатформенное. В приложенных файлах обработка, код которой на 90% приведен в публикации.

 

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

Наименование Файл Версия Размер
FillDocx

.epf 32,45Kb
37
.epf 32,45Kb 37 Скачать

Специальные предложения

Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. androgin 08.07.18 22:18 Сейчас в теме
код на англ., конечно красивый, но тут он гораздо более понятен на русском )
MegasXXX; leonidt84; 🅵🅾️🆇; PLAstic; CyberCerber; Дмитрий74Чел; unichkin; +7 1 Ответить
2. Артано 718 09.07.18 02:21 Сейчас в теме
(1) Если используются англоязычные объект или библиотека, то зачем уподобляться изобретателям ЕстьNull и городить двуязычный код?
alest; Lok`Tar; A_Max; +3 2 Ответить
23. 1sig 202 24.12.19 00:44 Сейчас в теме
(1) здесь https://infostart.ru/public/1171429/ реализация разбора xml на основе данной публикации, только по-русски)
автору данной публикации однозначно + за изящное решение и грамотное описание.
3. nodel0 26 09.07.18 04:04 Сейчас в теме
разбор docx без применения COM хорошо реализован в документообороте, можно там подсмотреть реализацию.
MegasXXX; Spartacus; PLAstic; user774630; nbeliaev; Bassgood; +6 Ответить
13. nbeliaev 09.07.18 17:24 Сейчас в теме
(3) (11) возможно. Может быть в рег. задании Извлечение текста что-то подобное используется. Не смотрел
4. rpgshnik 2731 09.07.18 06:37 Сейчас в теме
Нужно попробовать, а то был геморрой с сохранением стилей в шаблонах. Особенно проблем не было с подставлением в док, а в докх стиль сбрасывался(((
5. AlX0id 09.07.18 08:14 Сейчас в теме
Я для подставления параметров использовал, собственно, поля Word:
1. Добавил в шаблон пользовательское поле, в значение прописал что-то типа в8_НомерДоговора.
2. В файлике docProps\custom.xml просто заменил этот текст на значение параметра.

Этот файлик на порядок более структурирован, нежели document.xml, да и поменьше будет. С построителем DOM было бы красивее наверн, но лень же )
PLAstic; kare; +2 Ответить
6. AlX0id 09.07.18 08:15 Сейчас в теме
А вот с таблицами все значительно интереснее.. Приходится стараться не касаться их пятиметровой палкой..
7. Поручик 4547 09.07.18 08:16 Сейчас в теме
Похожий парсер работает в нашей конфигурации с 2013 года.
nbeliaev; +1 Ответить
8. qazaas 09.07.18 12:28 Сейчас в теме
For Each MapElement In FillData Do

XPathExpression = DomDocument.CreateXPathExpression("//w:t[contains(text(),'"+MapElement.Key+"')]", Resolver);
XPathResult = XPathExpression.Evaluate(DomDocument);

Node = XPathResult.IterateNext();
While Node <> Undefined Do

Node.TextContent = StrReplace(Node.TextContent, MapElement.Key, MapElement.Value);
Node = XPathResult.IterateNext();

EndDo;

EndDo;
Показать


Не понял, как вы получаете коллекцию "FillData"...
9. nbeliaev 09.07.18 13:33 Сейчас в теме
(8) Это псевдо коллекция. В обработке заполняется фейковыми данными
10. Сурикат 353 09.07.18 14:43 Сейчас в теме
а у вас не было проблем с XPath,когда в тегах документа были указаны пространства имен?
12. nbeliaev 09.07.18 17:22 Сейчас в теме
(10) была, но не в рамках этой задачи. В том файле была возможность это регулировать и я избавился от этого. По-другому так и не смог совладать. Было правда эта проблема года 1,5 назад. Может сейчас что-то и изменилось
11. morohon 09.07.18 16:43 Сейчас в теме
Насколько я помню в БСП 3.0 реализована работа с doc через XML
14. nytlenc 10.07.18 09:28 Сейчас в теме
ТабДок = Новый ТабличныйДокумент;
ТабДок.Прочитать(ИмяФайла, СпособЧтенияЗначенийТабличногоДокумента.Значение);
	
// Делаем что нужно
	
ТабДок.Записать(ИмяФайла, ТипФайлаТабличногоДокумента.DOCX);
15. user_gea 10.07.18 11:05 Сейчас в теме
Спасибо! Мне ваша публикация понравилась и в будующем пригодится
16. 🅵🅾️🆇 10.07.18 18:10 Сейчас в теме
В мемориз только потому, что не знал, что docx суть архив с xml.
Этож все в корне меняет.

Ух теперь заживем.
17. wbazil 130 11.07.18 08:48 Сейчас в теме
https://infostart.ru/public/237032/
что то похожее тоже без Com но на русском
18. nilabs 8 11.07.18 13:00 Сейчас в теме
малореально, если шаблон будут править юзеры.
MS WORD 2013
Прикрепленные файлы:
19. nilabs 8 11.07.18 13:03 Сейчас в теме
(18) что кстати в https://infostart.ru/public/237032/ в комментариях и пишут
20. Stim213 405 16.07.18 15:09 Сейчас в теме
Сохранил вордовский документ-шаблон в файл xml
ПутьКФайлу =  "C:\счета клиентов\шаблон.xml";


на сервере его читаю в текстовый док

ТекстДок = Новый ТекстовыйДокумент;
ТекстДок.Прочитать(ПутьКФайлу,кодировкатекста.UTF8);
текст = ТекстДок.ПолучитьТекст();


подставляю значения параметров

текст = стрЗаменить(текст,"$POSTADRESS",ПочтовыйАдрес);


сохраняю файл doc
текстДок2 = Новый текстовыйДокумент;
текстДок2.УстановитьТекст(текст);
текстДок2.Записать(ИмяФайлаДоговора,кодировкатекста.UTF8);



и все это без всяких заморочек с ком-объектами и пр.
WWWolfy; bogdan_sukonnov; Skin123; Трактор; +4 Ответить
21. bogdan_sukonnov 57 12.10.18 19:11 Сейчас в теме
(20) Отличная идея! Но работает нормально только при открытии файла в ворде. Опен офис, к сожалению, такой файл открывает как xml - а значит, наружу такой файл не пошлешь... В этом смысле актуальнее все-таки разархивировать docx, и сделать то, что Вы и рекомендуете уже там и заархивировать его назад. Там, правда, строка с нашей переменной может оказаться разорвана другими тегами, если при вводе пользователь нажимал что-то кроме нужного (шифт, удалял и т.п.). Так что перед использованием такого шаблона в 1С его желательно обработать макросом, вычищающим из наших переменных все мусорные данные форматирования.
22. ISP 20.08.19 08:25 Сейчас в теме
Пытаюсь сделать печатную форму word через БСП. В ней реализован такой же механизм как и в статье. Т.е работа через XML и сборка уже самого файла из отдельных XML.

Проблема в том, что 1C не видит параметры, которые надо заполнить. В вордоском макет написал

{v8 Область.Заголовок}
Согласие на обработку персональных данных
{/v8 Область.Заголовок}

но система разбора не видет эти области (в файле document вообще нет текста V8).

Как правильно сделать вордоский макет, чтобы 1C увидела параметры для заполнения
24. UtSpar 25.02.20 11:50 Сейчас в теме
А как быть с выводом нескольких строчек (таблицы)?
25. Greek26rusa 2 10.03.20 10:07 Сейчас в теме
Добрый день. А возможно ли получить данные перед заполнением. У нас в ворде есть параметры для заполнения можно ли их как то за ранее получить? и дать им значение а не за ранее описывать их.
26. WWWolfy 105 12.04.20 19:09 Сейчас в теме
Вот вам процедура, которая убирает разрывы в разобранном Word/DocX файле, стандартно это document.xml.
Я, например, использую её перед сохранением Шаблона docx в Хранилище 1С.
Шаблон на 5 страниц обрабатывает меньше секунды, имхо шустро.
А так как обрабатывать надо один раз, то и вообще отлично.

Лучше запускать её в Попытка/Исключение, на всякий случай.


// Убираем в Word / docx файле разрывы
// будет работать для параметров типа:   <Организация>
// ФайлXML  - строка, ссылка на файл document.xml
Процедура ОбработатьФайлПередСохранением( ФайлXML )
	//инициализация параметров
	ТегСтрокиТекста="w:t";
	СигнатураОткрывающая = "<";
	СигнатураЗакрывающая = ">";
	мУзлыКУдалению = Новый Массив;

	// читаем XML файл в  ПостроительDOM
	ЧтениеXML = Новый ЧтениеXML;
	ЧтениеXML.ОткрытьФайл(ФайлXML);
	ФайлDOM = Новый ПостроительDOM(); //
	DOM_XML = ФайлDOM.Прочитать( ЧтениеXML );
	ЧтениеXML.Закрыть();
	
	
	// ищем все случаи, когда скобка открыта (хоть раз) и не закрыта (ни разу)
	Resolver = New DOMNamespaceResolver(DOM_XML);
	XPathExpression = DOM_XML.CreateXPathEx * pression("//w:t[contains(text(),'"+СигнатураОткрывающая+"') and not(contains(text(),'"+СигнатураЗакрывающая+"'))]", Resolver);
	XPathResult 	= XPathExpression.Evaluate(DOM_XML);
		
	Node = XPathResult.IterateNext();
	Пока Node <> Undefined Цикл 
		стрПараметр = ""+Node.TextContent; //тут собираем строку
		мУзлыКУдалению.Очистить();   //тут собираем узлы от скобки < до скобки >, потом их удалим
		
		УзлыНиже = Node.РодительскийУзел;
		флНашлиЗакрывающуюСкобку = Ложь;
		Пока УзлыНиже.СледующийСоседний <> Неопределено И НЕ флНашлиЗакрывающуюСкобку Цикл
			УзлыНиже = УзлыНиже.СледующийСоседний;
			мУзлыКУдалению.Добавить( УзлыНиже );
			
			xml_Run_TextFragment = УзлыНиже;
			Для каждого xml_Text из xml_Run_TextFragment.ДочерниеУзлы Цикл
				Если xml_Text.ИмяУзла <>ТегСтрокиТекста Тогда Продолжить; КонецЕсли;
				
				стрПараметр = стрПараметр + xml_Text.TextContent;
				Если СтрНайти( xml_Text.TextContent, СигнатураЗакрывающая) >0 Тогда    // ищем  ">"
					флНашлиЗакрывающуюСкобку = Истина;
					Прервать;
				КонецЕсли;
			КонецЦикла; // ищем внутри Run_TextFragment
			
		КонецЦикла;  // идём к след. узлу
		
		//обрабатываем найденное
		Если флНашлиЗакрывающуюСкобку Тогда
			Node.TextContent = стрПараметр;
			//удаляем ненужные узлы, которые были от скобки до скобки
			Для Каждого текУзелУдалять Из мУзлыКУдалению Цикл 
				текУзелУдалять.РодительскийУзел.RemoveChild(текУзелУдалять);    //УдалитьДочерний
			КонецЦикла;
		КонецЕсли;
		
		// next
		Node = XPathResult.IterateNext();
	КонецЦикла;
	
	XMLWriter = New XMLWriter;
	XMLWriter.OpenFile(ФайлXML); 
	DOMWriter = New DOMWriter; 
	DOMWriter.Write(DOM_XML, XMLWriter); 
	XMLWriter.Close();

КонецПроцедуры
Показать
27. MegasXXX 2 17.08.20 12:18 Сейчас в теме
Спасибо, интересненько!
Всегда приятноо разбирать что либо не пользуясь COM и разного рода Application.
А то некоторые разбирают CSV с помощью ExcelApplication - оно открывается криво, медлено и вообще падает. А делов то, 5 минут написать парсер CSV
28. kirlog 91 14.12.20 20:20 Сейчас в теме
Спасибо, хорошая статья!

Но что с картинками? Можно ли таким способом менять картинки в документе docx?
29. nbeliaev 785 15.12.20 12:46 Сейчас в теме
Почему бы нет. Просто нужно оперировать xml узлами с картинками. И для картинок есть еще описание в отдельном файле. Точное название не вспомню сходу, что-то типа rel.xml (от слова relations).
30. falco 25.05.21 10:23 Сейчас в теме
Подскажите как вставить картинку в колонтитул DOCX
Оставьте свое сообщение

См. также

Безопасная работа с транзакциями во встроенном языке Промо

Практика программирования v8 1cv8.cf Абонемент ($m)

Разбираемся с опасностями использования транзакций во встроенном языке 1С. Познаем ошибку "В данной транзакции уже происходили ошибки". Учимся защищаться от них.

1 стартмани

25.03.2019    46578    tormozit    58    

Пример создания документа с движениями в ERP 2.5.7

БСП (Библиотека стандартных подсистем) Практика программирования v8 ERP2 Россия УУ Абонемент ($m)

Пример создания документа с движениями в ERP 2.5.7, а также включение документа в основные подсистемы, а именно по управлению доступом, датам запрета изменения, контролю остатков, использованию характеристик и серий и прочее.

1 стартмани

10.08.2021    2335    maraty    10    

Работа с абстрактным массивом

Математика и алгоритмы Практика программирования v8 Россия Абонемент ($m)

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

1 стартмани

07.07.2021    3930    kalyaka    56    

Семеро одного не ждут? Асинхронное исследование асинхронности

Работа с интерфейсом Практика программирования v8 1cv8.cf Абонемент ($m)

Все уже, наверное, знают о появлении в новых версиях платформы асинхронных функций и конструкций Асинх/Ждать. Многие, возможно, уже их используют. Но что будет, если создать свои асинхронные функции, запустить и не дожидаться окончания их выполнения? Неужели можно запустить несколько процессов параллельно?

1 стартмани

08.06.2021    5721    Alxby    46    

План подготовки к аттестации на 1С: Специалиста по платформе (+ Ссылки на материалы) Промо

Решение задач на 1С:Специалист v8 Россия Абонемент ($m)

Хочу поделиться собственным планом подготовки к аттестации на 1С: Специалист по платформе 8.3 со ссылками на материалы (и указанием стоимости).

1 стартмани

23.12.2017    25934    UtSpar    39    

БСП. Подключаемые команды. Команды заполнения

БСП (Библиотека стандартных подсистем) v8 ERP2 БП3.0 ЗУП3.x Россия Абонемент ($m)

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

1 стартмани

11.05.2021    7565    kondrp    7    

Модель запроса

Универсальные функции v8 v8::Запросы 1cv8.cf Россия Абонемент ($m)

Работа с текстом запроса напрямую не позволяет просто обратиться к определенному полю, таблице или условию. Однако, работая со схемой, можно добавить к существующему условию новое или вообще включить его в состав другой группы. Как ни странно, в типовых решениях часто можно встретить код работы с текстом запроса наряду с использование схемы. Возможно появление удобной библиотеки или нового объектного подхода позволит отказаться от работы с текстом совсем, а код построения запроса будет аутентичен исходному запросу, но без избыточности и доступный для простой модификации.

1 стартмани

01.03.2021    3022    kalyaka    25    

Как сдать экзамен 1С:Специалист по платформе?

Решение задач на 1С:Специалист v8 Россия Абонемент ($m)

Не пора ли получить сертификат 1С:Специалист по платформе? Для этого ...

1 стартмани

18.01.2021    18369    vasilievil    10    

Как выполнить отчет на СКД через COM и получить данные отчета? Промо

Практика программирования v8 УПП1 Россия Абонемент ($m)

Для чего это нужно. Например, нужно в одной базе получить какой-либо показатель из другой базы. Этот показатель вычисляется в каком-либо сложном отчете, который написан на СКД. Можно, конечно, "скопипастить" текст запроса из другой базы, немного подправить его и выполнять в том же COM подключении. Но с этим теряется гибкость: если отчет изменился, то нужно помнить о том, что где-то есть его "немного модифицированная" копия. В статье будет рассмотрен пример получения данных из базы ЗУП.

2 стартмани

08.05.2018    33644    wowik    3    

Запрещаем администратору системы заходить в конфигуратор (внешнее управление сеансами)

DevOps Сервера v8 Абонемент ($m)

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

1 стартмани

08.01.2021    2906    ardn    5    

Devops на коленке, или Иногда стоит отказаться от gitsync

DevOps Скрипты автоматизации v8 Россия Абонемент ($m)

В этой публикации описывается опыт выгрузки конфигурации в исходный код, ускорение выгрузки за счет отказа от использования gitsync в пользу своего решения.

1 стартмани

08.12.2020    1473    ardn    2    

СКД: все, что вы хотели знать о подмене схемы компоновки данных в отчетах и обработках

Практика программирования v8 v8::СКД 1cv8.cf Абонемент ($m)

Довольно часто на различных тематических форумах задается вопрос, можно ли использовать в отчете/обработке несколько схем компоновки данных, подменяя одну другой по мере надобности? При этом желательно, чтобы и пользовательские настройки при смене схемы менялись соответственно.

1 стартмани

07.12.2020    5393    user1502278    18    

Как нарисовать граф на 1С Промо

Практика программирования v8 Абонемент ($m)

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

1 стартмани

09.08.2013    73724    ildarovich    117    

Cбор и анализ ошибок при помощи Sentry, или как упростить жизнь себе и пользователям

Интеграция с сервисами Практика программирования v8 Абонемент ($m)

Цель данной статьи - сделать процесс сбора и анализа ошибок, происходящих в базе, максимально простым, быстрым и удобным, собирать статистику по ошибкам, местам их возникновения и частоте их появления, а также в деталях разобрать все тонкости по интеграции 1С с Sentry.

1 стартмани

09.10.2020    7894    hexhoc    12    

Программная корректировка при выводе отчета СКД

Практика программирования v8 v8::СКД 1cv8.cf Абонемент ($m)

Большинство отчетов на СКД, требующих программной корректировки, реализуются с помощью программной настройки СКД или обработки табличного документа уже после вывода отчета. Но во многих случаях более оптимально будет выполнять программную корректировку в процессе вывода отчета. Для этого существуют программные объекты, о которых я расскажу в данной статье.

1 стартмани

08.10.2020    11597    dabu-dabu    16    

Библиотека программного изменения формы (УФ)

Инструментарий разработчика Работа с интерфейсом Универсальные функции v8 1cv8.cf Абонемент ($m)

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

1 стартмани

07.08.2020    7113    BuriyLesha    20    

Простой способ индексирования интервалов Промо

Практика программирования v8 Абонемент ($m)

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

1 стартмани

28.09.2016    42243    ildarovich    22    

Загрузка, скачивание, удаление файлов с помощью НачатьПомещениеФайлаНаСервер() и НачатьПолучениеФайлаССервера()

Практика программирования v8 1cv8.cf Абонемент ($m)

В платформе 8.3.15 появились новые методы НачатьПомещениеФайлаНаСервер() и НачатьПолучениеФайлаССервера(). В данной статье рассмотрено готовое решение проверенное и прекрасно работающее на тонком и веб-клиенте.

1 стартмани

25.07.2020    12573    Flashill    15    

Работа с хранилищем конфигурации из режима 1С: Предприятие минуя конфигуратор

Хранилище v8 1cv8.cf Абонемент ($m)

Описание приемов работы с хранилищем конфигурации 1С из режима 1С: Предприятие минуя конфигуратор. Статья содержит ряд примеров работы с хранилищем по протоколу HTTP, описание "внутренностей", а также демонстрационную обработку

3 стартмани

11.06.2020    7459    MaxxG    19    

История данных и БСП

БСП (Библиотека стандартных подсистем) v8 1cv8.cf Абонемент ($m)

История данных от платформы и Версионирование объектов от БСП. Как мигрировать историю из подсистемы БСП и начать использовать функции платформы уже сейчас.

1 стартмани

09.06.2020    5315    zeegin    17    

Бесплатная проверка контрагентов в ФНС (общий модуль с алгоритмом). На примере выводим статус в список справочника контрагентов Промо

Практика программирования v8 1cv8.cf Абонемент ($m)

Если вам интересно проверить контрагенте в ФНС, вам поможет данная публикация. Весь алгоритм работы строится на основе данных, полученных с сервиса http://npchk.nalog.ru совершенно бесплатно.

1 стартмани

01.02.2018    38664    rpgshnik    59    

Управление состоянием для шаблона MVC и работы с данными объекта

Работа с интерфейсом v8 1cv8.cf Абонемент ($m)

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

1 стартмани

18.03.2020    4303    kalyaka    35    

Методика обновления формы объекта данных при изменении объекта

Практика программирования v8 v8::УФ 1cv8.cf Абонемент ($m)

В формах объектов данных часто встречаются элементы, косвенно связанные с объектом. Логику обновления этих элементов при изменении объекта обычно вызывают из обработчиков ПриСозданнииНаСервере и ПриОткрытии, забывая про наличие других способов изменения объекта. В статье предложена методика для обычных и управляемых форм, учитывающая все способы.

1 стартмани

09.03.2020    21858    tormozit    16    

БСП: Дополнительная обработка (Регламенты), примеры от простого к сложному Промо

БСП (Библиотека стандартных подсистем) Практика программирования v8 1cv8.cf Абонемент ($m)

Очень много попадается странных решений, которые можно решить через БСП:Дополнительные отчеты и обработки. Я бы вообще БСП из-за этой подсистемы переименовал в «Большое Спасибо Программистам». Поработаем с подсистемой в части написания регламентных заданий.

1 стартмани

10.05.2018    55260    dsdred    46    

Отправка уведомлений с помощью командной строки, Оповещения с сервера на клиент с помощью командной строки

Практика программирования v8 1cv8.cf Россия Абонемент ($m)

Отправка уведомлений с помощью команды командной строки msg. Оповестить пользователей из серверного модуля или регламентного задания, с помощью командной строки msg.

1 стартмани

05.03.2020    8299    user5300    3    

Вывод сообщений в HTML поле средствами 1С

Практика программирования v8 v8::УФ Абонемент ($m)

Пример использования вывода большого количества сообщений в поле HTML. С возможностью открывать ссылочные объекты и создавать новые объекты передавая параметры прямо из HTML поля. Протестировано на релизах 8.3.12 и 8.3.15+

2 стартмани

31.01.2020    12081    burni4    16    

Краткое руководство по внесению изменений в конфигурацию

Практика программирования v8 1cv8.cf Абонемент ($m)

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

1 стартмани

13.01.2020    23250    sapervodichka    41    

Некоторая работа с данными через COM Промо

Практика программирования v8 Абонемент ($m)

В статье приведены примеры работы с Платформой 8.X через COM (точнее, через объект COMConnector). Примеры кода были использованы при реализации прикладных задач в процессе трудовой деятельности.

2 стартмани

05.12.2012    60204    wowik    32    

Заполнение шаблона Word docx на сервере, без ComОбъект и внешних компонент, только механизмами самой Платформы 1С, методом XML-инъекции

Универсальные печатные формы Печатные формы документов v8 v8::УФ 1cv8.cf Россия Абонемент ($m)

Внешние печатные формы для документа Счет на оплату позволяют сформировать на сервере без использования технологии OLE (Com объекта) и сохранить на печать заполненные docx шаблоны договора поставки и спецификации к договору (УНФ 1.6) (идея универсальна, подойдет для любой конфигурации). Используются только средства самой Платформы 1С:Предприятие 8.3 (8.3.13.1644). Проверено на релизах УНФ 1.6.16.176, 1.6.26.132.

1 стартмани

23.12.2019    19678    69    1sig    3    

Интеграция 1С и Active Directory на сервере

Скрипты автоматизации v8 v8::УФ Россия Абонемент ($m)

Получить информацию Active Directory на управляемых формах со стороны сервера, под любым пользователем домена.

1 стартмани

21.12.2019    15168    DrZombi    16    

Разбираемся с web-kit в 1С, на примере интеграции TinyMCE в управляемую форму в УТ 11.4. Допиливаем обмен с сайтом в УТ 11.4

Обмен данными и распределенная БД Интеграция с сервисами Адаптация типовых решений v8 v8::УФ УТ11 Абонемент ($m)

Многие уже знают, что в релизе платформы 8.3.14.1565, браузер Internet Explorer был заменен на Web-Kit, это на самом деле большой шаг вперед, но я уверен, многим, как и мне, пока не совсем понятно, что к чему. Возник опыт использования web-kit в 1С, вызова JS из 1С и вызова 1С из JS. Давайте вместе попробуем понять, чем одно отличается от другого, и заодно сделаем, что-нибудь полезное. Да и наверняка многим придется переписывать свои подобные поделки после обновления на новую платформу, так что надеюсь мой опыт окажется полезным.

2 стартмани

08.12.2019    9771    Бэнни    25    

Работа со схемой запроса Промо

Инструментарий разработчика v8 v8::Запросы Абонемент ($m)

Стандартом взаимодействия с реляционной базой данных стал язык SQL. Приемником SQL в 1С является язык запросов. Язык запросов, также как и SQL, является структурированным. Составляющие структуры запроса отвечают на разные вопросы о том, какие данные требуется получить и какие манипуляции с множествами данных необходимо произвести при получении. В простых случаях текст запроса можно написать вручную, однако в сложных случаях, а также при программном формировании, - лучше воспользоваться объектной моделью запроса и использовать объект "Схема запроса". В статье дается описание объектной модели и особенностей работы с ней, а также приводится решение, упрощающее взаимодействие с объектом "Схема запроса".

1 стартмани

24.04.2018    52565    kalyaka    41    

Генерация управляемой формы на основе обычной (proof of concept)

Работа с интерфейсом v8 v8::УФ 1cv8.cf Абонемент ($m)

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

1 стартмани

06.11.2019    9416    user700211_a.straltsou    28    

Массовое изменение режима поддержки объектов конфигурации

Структура метаданных v8 1cv8.cf Абонемент ($m)

Что делать, если при сравнении/объединении конфигураций нужно изменить режим поддержки для большого количества объектов? Штатного механизма для выполнения подобной задачи в Платформе нет. Изменять режим для всей конфигурации? Описывается способ, позволяющий выполнить изменение режима только для нужных объектов.

05.11.2019    5044    VKislitsin    12    

"Живые" картинки со Snap.SVG

WEB Работа с интерфейсом Практика программирования v8 Абонемент ($m)

В статье рассмотрен пример использования http-сервисов для визуализации данных

1 стартмани

24.10.2019    15263    blackhole321    7    

Многопоточность. Универсальный «Менеджер потоков» (фреймворк) с отслеживанием зависимости объектов Промо

Математика и алгоритмы Универсальные функции HighLoad оптимизация Практика программирования v8 1cv8.cf Россия Абонемент ($m)

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

26.05.2017    51623    DarkAn    87    

Полное копирование одной формы в другую

Универсальные обработки Работа с интерфейсом Практика программирования v8 1cv8.cf Абонемент ($m)

Однажды я столкнулся с необходимостью открыть форму ЛЮБОГО документа с определенными изменениями, не зависящими от структуры объекта (например, заблокировать все кнопки). В интернете решения я не нашел. Обычно на форумах на запросы подобного рода отвечают чем-то вроде "покажи первоначальную задачу, а не спрашивай как реализовать то, что ты придумал". Тем не менее, мне стало интересно, как это можно сделать.

1 стартмани

03.10.2019    8310    nekit_rdx    25    

Многопоточная обработка данных на примере перепроведения документов

Обработка документов Практика программирования v8 ERP2 УТ11 КА2 Абонемент ($m)

Дальнейшее развитие темы фоновой обработки данных - проведение документов в потоках. Настройка параметров и запуск основного процесса (менеджера потоков). Разбивка документов для проведения на не связанные друг с другом наборы и запуск дополнительных фоновых заданий для отдельных потоков. Отслеживание выполнения каждого потока в родительском сеансе.

1 стартмани

17.09.2019    13165    ids79    46    

Описание формата внутреннего представления данных 1С в контексте обмена данными

Внешние источники данных Практика программирования v8 v8::УФ 1cv8.cf Абонемент ($m)

Фирма 1С не рекомендует использовать внутреннее представление данных для любых целей, которые отличны от обмена с 1С:Предприятием 7.7. Но сама возможность заглянуть на "внутреннюю кухню" платформы с помощью функций ЗначениеВСтрокуВнутр(), ЗначениеВФайл(), ЗначениеИзСтрокиВнутр() и ЗначениеИзФайла(), дала возможность сообществу программистов 1С разработать новые приемы разработки и анализа. Так, именно на использовании внутреннего представления был построен алгоритм "быстрого массива", который позволяет практически мгновенно создать массив в памяти на основании строки с разделителями. С помощью разбора внутреннего представления можно "на лету" программным кодом выполнить анализ обычной формы и даже сделать редактор графической схемы. Во внутреннем формате сохраняют свои данные между сеансами различные популярные внешние обработки. А еще это возможность сделать быстрый обмен с внешними системами.

1 стартмани

06.09.2019    21958    Dementor    31    

Агрегатное суммирование строк в запросе – сложно, но не невозможно Промо

Математика и алгоритмы v8 Абонемент ($m)

Описывается метод соединения строк из одной колонки таблицы в единую результирующую строку в запросе на языке 1С. Метод сложный и по сравнению с внезапросной техникой представляет больше спортивный, чем практический интерес.

1 стартмани

09.09.2013    85465    ildarovich    57    

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

Практика программирования v8 Абонемент ($m)

Если Вам часто приходится просматривать в отладчике сложные пакетные запросы с большим количеством временных таблиц, то эта статья для Вас.

1 стартмани

27.08.2019    13080    ids79    22    

Запуск фонового задания во внешней обработке. Отключение предупреждений защиты от опасных действий в фоновом задании

Практика программирования v8 1cv8.cf Абонемент ($m)

Как запустить фоновое задание из модуля внешней обработки используя БСП. Как отключить безопасный режим и сообщения защиты от опасных действий независимо от профиля безопасности пользователя в фоновом задании во внешней обработке.

2 стартмани

24.08.2019    17665    BenGunn    26    

Изменяющееся контекстное меню в 1С 8.3

Работа с интерфейсом Инструментарий разработчика Практика программирования v8 v8::УФ Абонемент ($m)

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

1 стартмани

06.08.2019    23053    signum2009    16    

Новый запрос и новая таблица значений как функции Промо

Практика программирования v8 Абонемент ($m)

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

1 стартмани

27.11.2012    46592    ildarovich    49    

Менеджер потоков: реализация "любой" задачи в потоках

HighLoad оптимизация Инструментарий разработчика v8 Абонемент ($m)

Менеджер потоков – один их новых инструментов, который упрощает работу разработчиков. Насколько легко с ним, на конференции Infostart Event 2018 Education показал начальник отдела автоматизации 1С Иван Филимонов компании «Трансстроймеханизация».

01.08.2019    11544    DarkAn    7    

Процедура ПриКомпоновкеРезультата

Практика программирования v8 1cv8.cf Абонемент ($m)

Коллекция кода

1 стартмани

26.07.2019    60692    vasilev2015    67    

10 способов получить модуль числа (а может, и больше)

Инструментарий разработчика Практика программирования v8 1cv8.cf Абонемент ($m)

Пишем функцию вычисления модуля числа. Сколько способов существует? Давайте посчитаем!

1 стартмани

11.07.2019    15232    sam441    34    

Уровни, глубина, прародители, циклы и аналоги запросом Промо

Практика программирования v8 1cv8.cf Абонемент ($m)

В продолжение публикации «Транзитивное замыкание запросом» [http://infostart.ru/public/158512/] добавлены другие варианты использования того же приема. Приведены запросы для быстрого определения уровней всех элементов справочника, максимальной глубины справочника, прародителей произвольных элементов справочника, запрос для быстрого определения циклов (на примере справочника спецификаций «1С:Управление производственным предприятием») и определения множеств аналогов номенклатуры (также на примере конфигурации «1С:Управление производственным предприятием»).

1 стартмани

13.11.2012    120903    ildarovich    102    

Мониторинг производительности и искусственный интеллект

HighLoad оптимизация Искусственный интеллект (AI) Практика программирования v8 Абонемент ($m)

Расскажем и покажем практически, как использовать искусственный интеллект на страже мониторинга производительности. У вас появится возможность создать собственного помощника Ларису, которая возьмет на себя вопросы по контролю и диагностике состояния обслуживаемой системы.

1 стартмани

01.07.2019    10451    ivanov660    28    

Шифрование текста и файлов с помощью 1С. Используется хеш-код SHA256, Без Capicom, Архиваторов и сторонних служб

Защита и шифрование v8 1cv8.cf Абонемент ($m)

Данная статья описывает простейший собственный алгоритм шифрования средствами 1С. Без Capicom, Архиваторов и сторонних служб. Данный метод работает на Платформе 8.3 и т.п. 09.07.19 Добавлена обработка шифрования файлов

1 стартмани

26.06.2019    12517    Indgo    46    

"Убер на складе": динамический расчет маршрутов с учетом реальных расстояний

Учет ТМЦ Учет ТМЦ Практика программирования v8 УУ Абонемент ($m)

Представляю методику и инструмент для динамического расчета маршрутов отбора на высоконагруженных складах для максимального повышения эффективности склада, ускорения проходимости и, как следствие, экономии денег. Это методика и обработка для интеграции в WMS решения. Тестировалось на 1С 8.3.14.1565.

3 стартмани

24.06.2019    19863    informa1555    17    

1С:Ассемблер. Немного летнего веселья!

Инструментарий разработчика Практика программирования v8 1cv8.cf Абонемент ($m)

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

1 стартмани

21.06.2019    34361    Evil Beaver    147