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

Публикация № 1421272 16.04.21

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

Программист - это человек, непрерывно принимающий решения. Написание кода не является процессом принятия решения - это всего лишь трансляция ваших желаний. Если вас периодически тяготит написание сотен строк кода ради решения задач, то прошу обратить внимание. Данный продукт позволит существенно сократить время на рутинные операции при разработке. За счет библиотечной реализации сокращается объём кода, а его читаемость повышается. К библиотеке прилагается документация API и шаблоны кода для наиболее популярных методов.
 
 Обзор наиболее крупных и "вкусных" блоков функциональности

 I. Запросы:
1. Существующая функциональность:

 - Универсальные, легко переопределяемые запросы к физическим и виртуальным таблицам.
 - Конструктор параметров запросов. Отборы, поля, сортировки, итоги и др. Возможность слияния и/или дополнения нескольких параметров (например, дефолтные и пользовательские).
 - Автогенерируемые запросы. Декларативные запросы к любым физическим и виртуальным таблицам с любыми отборами.
 - Автогенерируемые запросы. Возможность запроса по нескольким таблицам одного класса (документы, справочники и.т.п.).
 - Повторное использование единожды написанных запросов. Конструктор позволяющий получить результат запроса или сам запрос на основании существующего шаблона запроса и переданных параметров.
 - Возможность построения единого интерфейса обращения к данным, с использованием прокси поддерживающего автогененируемые, перепределенные разработчиком и произвольные запросы через один и тот же интерфейс. То есть обращение к данным всегда осуществляется через одну и ту же точку входа, будь то поиск документа, получение стандартной или переопределенной выборки из таблицы БД или абсолютно произвольного запроса по его имени.
 - Удобная опция по помещению результата запроса в контейнер (РезультатЗапроса, ТаблицаЗначений, ДеревоЗначений, Массив, СписокЗначений, Структура). По умолчанию включена в проксируемые запросах, но доступна для использования и независимо.


2. Планы развития (уже есть решения в тестовых ветках, но не было большой потребности в доведении до релиза):
а. Пакетные запросы.
б. Запрос-объединение и/или пакетный запрос с независимыми наборами таблиц и параметров.

II. Расширение классов ДокументОбъект, справочникОбъект, ПВХОбъект и частично их менеджеров.
1. Существующая функциональность:
 - Улучшенный поиск взамен функций НайтиПо... Поддерживает сложные отборы.
 - Улучшенный поиск взамен функции Выбрать(). Поддерживает более сложные отборы, позволяет более тонко настраивать результат запроса. Для деталей см. параграф I
 - Новый конструктор для инициализации новых объектов как при создании, так и по ссылке. При создании сразу можно передать данные заполнения.
 - Упрощенный интерфейс для работы с БД. Функции Провести(), Распровести(), ПометитьНаУдаление(), СнятьПометкуНаУдаление() возвратом флага успеха/неуспеха операции
д. Логирование ошибок. Возможность переопределения формата записи ошибки в ЖР (при инициализации объекта). Также, текст исключения может быть получен для иных операций. 
 - Безопасная запись с соблюдением правил работы с транзакций. Функциональность по умолчанию работает так как заложено платформой, но предусмотрено гибкое переопределение поведения объекта в случае ошибок. Например не бросать исключение если запись не удалась, а пробросить информацию об исключении в вызывающий код или не регистрировать ошибку в ЖР, а лишь сообщить о ней пользователю.
 - Расширение событийной модели. Добавлена возможность обработки событий: ДоНачалаТранзакции, ПослеФиксацииТранзакции, ПослеОтменыТранзакции.
 - Мелкие удобства типа встроенной проверки наличия реквизита в объекте и изначально заполненного реквизита ссылка сразу после инициализации объекта.

III. Класс менеджер для упрощенной работы с внешними обработчиками.
 1. Параметризуемая инициализация с учетом опций безопасного режима и защиты от опасных действий. 
 2. Ведение списка инициализированных объектов
 3. Выборочная или полная деструкция инициализированных менеджером объектов.

IV. Движение по регистрам.

 1. Движение по регистрам накопления без описания движений в документе. В обработке проведения вызывается функция ДвиженияПоРегистрам, куда передаются метаданные регистра, таблица движений (как правило это выгрузка из ТЧ).
 2. Движения можно выполнять в режиме эмуляции. В этом случае движения не будут записаны, а вернутся в виде таблицы значений.
 3. Автоматически накладывается управляемая блокировка на регистр. Если блокировка недоступна, то накладывается автоматическая блокировка средствами платформы.
 4. Для регистров остатков предусмотрен подбор и контроль отрицательных остатков по набору измерений.
 5. При необходимости, алгоритм подбора остатков может быть переопределен для выбранных регистров. В данном случае, специализированный класс-расширение для менеджера регистра накопления, выполнит не собственный универсальный метод, а запросит переопределенный регистр и вернет полученный результат. Подробнее см. параграф V.

V. Расширение классов РегистрНакопленияМенеджер и РегистрСведенийМенеджер.
1. Существующая функциональность:
 - Возможность получить срезы данных со сложным отбором, как на определенную дату/момент времени, так и актуальные.
 - Возможность выполнения движений по регистру с подбором остатков при списании (для РН с видом остатки). Подбор производится по классической схеме с контролем остатков до движения, при этом можно переопределить поведение выбранного регистра и отключить контроль. При подборе автоматически подбираются измерения и ресурсы.
 - Возможность для гибкого переопределения. Может быть переопределено всё - от текста запроса остатков (по-умолчанию генерится автоматически), до набора измерений и параметров списания ресурсов. Переопределение осуществляется созданием соответствующего API в переопределяемом регистре. Интерфейс создаётся через прилагаемый к библиотеке каталог шаблонов без написания кода вручную.
2. Планы развития (уже есть решения в тестовых ветках, но не было большой потребности в доведении до релиза):
 - Добавить поддержку прочих регистров, по которым могут выполняться движения. Приоритет реализации: регистры бухгалтерии, регистры расчета.

VI Динамическая подмена кода.
1. Существующая функциональность:
 - Возможность подмены модулей объектов, менеджера и и.т.д. Как целиком так и фрагментарно (здесь потребуются точки входа в отдельных методах)
 - Подмена реализуется через создание точек входа в часто изменяемых участках кода. При первом обращении выполняется правка, создание точки входа и обновление. При повторном обращении код подменяется без обновления.
 - В случае получения отчетов/обработок через единый метод подсистемы, точки входа не нужны.
 - При следующем (плановом) обновлении, замененный код, снова будет выполняться из "родного" источника, а не из внешнего обработчиками. То есть не нужно беспокоиться о том, когда и в каких объёмах будет обновление. Достаточно, чтобы велся версионный контроль в репозитории конфигурации. Принцип работы подсистемы - "подменил и забыл", по аналогии с системами управляемого вооружения класса "выстрелил и забыл".

VII Расширение класса таблиц. Преимущественно ТЗ, но в ряде случаев поддерживаются все возможные таблицы от дерева значений до результата запроса и табличной части.
1. Существующая функциональность:
 - Конструкторы для новой пустой ТЗ по результату запроса и по метаданным.
 - Конструктор кросс-таблицы из обычной таблицы с возможностью выбора списка измерений строк и целевого показателя.
 - Конструктор по выборке. В отличие от конструктора по результату запроса позволяет сформировать или дополнить таблицу по части данных (если выборка с итогами), а не по всему результату запроса.
 - Сложение/вычитание таблиц по аналогии со сложением и вычитанием матриц, но с поддержкой матриц разного размера, где матрицы приводятся к единому размеру виртуально по набору измерений.
 - Добавление недостающих и расширение несуществующих методов как то: отбор по сложному отбору, дополнение таблицы не только строками но и колонками, итоги по отбору, удаление по отбору, нумерация, индексация, конвертация в массив массивов и обратно, вывод в табличный документ и др.
 - Объединение таблиц "как в запросе" с объединением типов колонок. Добавление колонки с объединением типов, если колонка уже существует.

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

Библиотека позволяет решать комплекс проблем за счет нескольких стратегических решений, которые вы можете принять и осуществить с использованием библиотеки:

I Стандартизация и сокращение объема кода. Повышение его предсказуемости и безопасности

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

- За счет сокращения объёма кода, который необходимо написать

- За счет сокращения объёма кода, который необходимо перечитать хотя бы раз (в реальной разработке бывает намного чаще)

- За счет стандартизации методологии разработки, что сокращает число обидных ошибок, когда забыл обработать исключение или неверно откатил транзакцию.

 
 Пример I-1. Сравнение способов записи группы объектов.

 

 
 Пример I-2. Движения по любому регистру накопления для любого документа в 1-2 строки

 

II Сокращение числа зависимостей между интерфейсами и архитектурой БД. 

Отказ от десятков, а то и сотен зависимостей между кодом и архитектурой, за счет повторного использования текстов запроса или их автоматической генерации. Это также позволяет экономить на поддержке текстов запросов.

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

В руках опытного специалиста, библиотека станет надежным помощником в деле изоляции интерфейсов от архитектуры БД. Как следствие - повышение гибкости программы и облегчение её сопровождения.

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

Нет необходимости собирать тексты запроса программно или делать костыли типа Не &ОтборПоОрганизации Или Организация = &Организация. Запросы параметризуются как по вашим настройкам, так и автоматически.

Фактически, это является реализацией на 1с MVC паттерна (MVC - ссылка вики) с предусмотренной защитой от наиболее распространенной ошибки применения паттерна - толстые контроллеры.

 

 
 Пример II-1. Запросы данных

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

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

 
 Решение 1. Запрос данных из физической таблицы (справочники, документы, регистры и.т.д.)
 
 Решение 2. Запрос данных из нескольких физических таблиц одного класса (несколько документов или справочников и.т.д.)
 
 Решение 3. Запрос данных из виртуальной таблицы (остатки, обороты, срез последних и.т.д.)
 
 Решение 4. Запрос данных с повторным использованием текста запроса
 
 Решение 5. Поиск ссылок по отбору

 

 
 Пример II-2. Регистрация исключений

 

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

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

 
 Пример III-1. Работа с таблицами
 
 Конструкторы таблиц
// по другой таблице, включая результаты запроса, деревья и табличные части
ИсключаемыеКолонки = "Сумма";
Результат = Таблицы_ауф.ТаблицаЗначенийПоРезультатуЗапроса(РезультатЗапроса,, ИсключаемыеКолонки);

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

// формирование кросс таблицы по ТЗ, ТЧ, данным формы
ИзмеренияСтрок = "Клиент,Договор";
ИзмерениеКолонок = "Организация";
Показатель = "Сумма";
Результат = Таблицы_ауф.КроссТаблица(Таблица, ИзмеренияСтрок, ИзмерениеКолонок, Показатель);

// формирование таблицы путём объединения других таблиц. Количество не ограничено.
// Работает как Объединить в запросе
Таблицы = МассивТаблицДляОбъединения();
ТолькоУникальныеЗаписи = Истина;
Результат = Таблицы_ауф.КроссТаблица(Таблицы , ТолькоУникальныеЗаписи);

 

 
 И много других полезных методов расширяющих возможности таблиц

 

 
 Пример III-2. Работа с массивами

 

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

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

 

IV Облегчение тестирования и отказ от динамического обновления.

 

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

 

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

 

Подменить можно отдельную функцию, фрагмент кода, целый модуль (общий модуль, объекта, менеджера и.т.д.), обработку/отчет целиком, а при некоторых ограничениях и документ/справочник и другие ссылочные типы.

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

При этом обеспечивается версионная целостность данных и плановое обновление, когда оно всё таки произойдет, не сломает внеочередные заплатки, а дополнит их.

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

 

ВАЖНО! Позитивные свойства данной системы обеспечиваются версионированием данных и централизованной разработкой. Если данный механизм будет использоваться бессистемно в рамках парадигмы "хренак-хренак и в продакшн", то данная подсистема станет отличным способом отстрелить себе ногу.

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

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

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

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

// ВАЖНО!!! Рекомендуется пользоваться прилагаемыми к поставке шаблонами текста

 

 

V Совместимость

 
 Старые версии платформы

 Библиотека работает даже на 8.1. На более старых нет опыта интеграции.

Для раритетных версий платформы в комплект поставки включены опциональные модули обеспечивающие совместимость.

В случае проблем, автор берет на себя обязательство обеспечить обратную совместимость в счет стоимости библиотеки. В случае невозможности гарантируется возврат денег.

 
 Использование модальности

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

 

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

Причины купить

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

Реализованная в библиотеке поддержка правильного MVC паттерна позволит реализовать гибкие программные решения.

Сравнение версий

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


Вопросы возврата

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


Заказать подбор решения


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

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

1.13.321 1 4200 руб.

1.13.319 1 18000 руб. Запросить демо

0 7500 руб.

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

Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. sashocq 192 22.04.21 16:20 Сейчас в теме
Вообще непонятно для чего это.
Несколько функций, на разбор которых что они делают и для чего нужны нужно потратить времени не меньше, чем на написание.

Половина функций работы с массивами я сразу вижу, что они уже есть в БСП.

А ещё есть какая-то полная поставка аж за 15 тыщ. И упоминается какая-то загадочная "динамическая подмена кода", что это?

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

Это о чём?

Позитивные свойства данной системы обеспечиваются версионированием данных и централизованной разработкой

Это для кого написано??? Для бухов или для разработчиков всё же?

Может, конечно, это что-то крутое. Но из описания совершенно непонятно что это. + наверное кто-то поставил просто чтобы в закладки внести.
2. Техподдержка 22.04.21 16:46
(1)
Здравствуйте, благодарю, что не прошли мимо.

Вообще непонятно для чего это.
- в анонсе и в названии статьи об этом и написано. Для сокращения издержек на воспроизведение и сопровождение часто используемых алгоритмов

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

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

А ещё есть какая-то полная поставка аж за 15 тыщ
почему аж? Это окупится максимум за месяц, в зависимости от специфики работы.

И упоминается какая-то загадочная "динамическая подмена кода", что это?
- альтернатива динамическому обновлению.

Это о чём?
дело в том, что на практике не раз встречал различные кустарные методики подобные этой, но не обеспечивающие контроль версий, бесшовность и вообще беспроблемность при обычных обновлениях и.т.д.

Это для кого написано??? Для бухов или для разработчиков всё же?
вообще для программистов. С первых до последних слов. Программист является даже первым словом в данной публикации.

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

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

См. также

Infostart Toolkit Промо

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

Простые и удобные инструменты: Консоль запросов, СКД, Редактор объекта, Поиск ссылок и другие. Редактор запросов и кода с раскраской и контекстной подсказкой. Улучшенный конструктор тонкого клиента и др.

9000 руб.

02.09.2020    63358    285    327    

Автоматическая выгрузка данных 1С 8.3 в Yandex Datalens (БД Clickhouse)

WEB-интеграция Инструментарий разработчика Облачные сервисы, хостинг Управляемые формы Анализ и прогнозирование 8.3.14 1С:Розница 1С:Управление нашей фирмой 1.6 1С:Документооборот 1С:ERP Управление предприятием 2 1С:Зарплата и кадры государственного учреждения 3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Управление холдингом 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x 1С:CRM ПРОФ, КОРП Россия Платные (руб)

Готовое решение для автоматизированной выгрузки данных из 1С 8.3 в базу данных ClickHouse для работы с данными 1С в Yandex Datalens (и не только) Хочу представить вашему вниманию нашу новую разработку - "Экстрактор данных 1С в BI". Решение отлично работает со всеми типовыми (и не только) конфигурациями 1С 8.3 для управляемых форм. И позволяет автоматизировать работу бизнес-аналитика по ежедневной выгрузке данных из 1С в БД ClickHouse для последующей работы с этой БД в Yandex Datalens

36000 руб.

15.11.2022    1156    0    11    

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

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

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

2400 руб.

24.09.2019    15990    8    11    

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

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

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

3000 руб.

27.08.2019    12043    3    6    

SALE! 25%

PowerTools Промо

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

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

2400 1800 руб.

14.01.2013    154859    925    0    

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

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

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

5000 руб.

07.02.2018    89219    216    92    

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

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

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

2040 руб.

27.12.2017    23609    2    10