Эмулятор COM-соединения или "объект" ЭтаБаза

25.11.15

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

Предыстория: был инструмент для работы с другой базой по COM-соединению. Потребовалось использовать этот инструмент для текущей базы (без COM-соединения), но без дублирования кода. Но, к сожалению, 1С не предоставляет объекта ЭтаБаза (ТекущаяБаза и т.п.), который бы позволял обратиться к глобальным перечислениям (менеджерам объектов Справочники, Документы и др.) через точку и создавать новые объекты.
Для этого на скорую руку был создан Эмулятор COM-соединения, который решает 2 вышеуказанные проблемы. Иначе говоря, предоставляет возможность сослаться на текущую базу данных аналогично COM-объекту (с некоторыми ограничениями).

Файлы

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

Наименование Скачано Купить файл
ЭмуляторCOMСоединения
.epf 6,36Kb ver:1.0
9 2 500 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

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

Далее привожу в сравнении идентичные синтаксически конструкции для COMСоединение ЭмуляторCOMСоединения.

Но прежде - "установка соединения":

    // COMСоединение
    v8 = Новый COMObject("V83.COMConnector");
    ДругаяБаза = v8.Connect(СтрокаСоединения);
    // ЭмуляторCOMСоединения

    ЭтаБаза = ВнешниеОбработки.Создать(Путь_к_обработке\ЭмуляторCOMСоединения.epf);

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

Работа с менеджерами объектов:

    // COMСоединение	
    Ссылка = 
ДругаяБаза.Справочники.Номенклатура.НайтиПоНаименованию(Товар);

    ВнОбработка = 
ДругаяБаза.ВнешниеОбработки.Создать(Путь_к_некоторой_обработке);
    // ЭмуляторCOMСоединения
    Ссылка = 
ЭтаБаза.Справочники.Номенклатура.НайтиПоНаименованию(Товар);

    ВнОбработка = 
ЭтаБаза.ВнешниеОбработки.Создать(Путь_к_некоторой_обработке);

 

Создание новых объектов встроенных типов (Запрос и т.п.):

 

    // COMСоединение

    Запрос = ДругаяБаза.NewObject("Запрос");
    Запрос.Текст = "
    |Выбрать
    |    Курс КАК Курс
    |Из
    |    РегистрСведений.КурсыВалют.СрезПоследних(&НаДату,
    |        Валюта = &Валюта)
    |";
        
    Запрос.УстановитьПараметр("НаДату", НаДату);
    Запрос.УстановитьПараметр("Валюта", 
ДругаяБаза.Справочники.Валюты.НайтиПоНаименованию(Валюта));
    
    Выборка = Запрос.Выполнить().Выбрать();
    // ЭмуляторCOMСоединения

    Запрос = ЭтаБаза.NewObject("Запрос");
    Запрос.Текст = "
    |Выбрать
    |    Курс КАК Курс
    |Из
    |    РегистрСведений.КурсыВалют.СрезПоследних(&НаДату,
    |        Валюта = &Валюта)
    |";
        
    Запрос.УстановитьПараметр("НаДату", НаДату);
    Запрос.УстановитьПараметр("Валюта", 
ЭтаБаза.Справочники.Валюты.НайтиПоНаименованию(Валюта));
    
    Выборка = Запрос.Выполнить().Выбрать();

 

Как можно увидеть, конструкции полностью идентичны.

 

Ограничения

  1. Невозможно вызывать методы глобального контекста/глобальных модулей, такие как XMLСтрока
  2. Можно вызывать методы неглобальных общих модулей (в 8.3), только если изменить слегка саму обработку (см. секреты)

Секреты

  1. Для получения экспортных переменных обработки, имеющих те же названия, что и встроенные переменные глобального контекста, использованы реквизиты обработки с типом "Произвольный"
  2. "Переопределение" функции NewObject COM-объекта возможно лишь потому, что нет одноименного метода глобального контекста. Он называется Новый/New
  3. Обращение к методам неглобальных общих модулей возможно, если создать одноименный реквизит обработки и инициализировать его в модуле обарботки.

Заключение

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

 

P.s. данный вопрос уже поднимался здесь: http://www.forum.mista.ru/topic.php?id=590517

Данный "эмулятор" является частичным решением

Вступайте в нашу телеграмм-группу Инфостарт

COMСоединение COMConnector ЭтаБаза ТекущаяБаза

См. также

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

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

24900 руб.

20.08.2024    60569    323    160    

292

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

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

16500 руб.

02.09.2020    245878    1350    419    

1128

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

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

15250 руб.

25.08.2025    42087    86    26    

99

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

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

22570 руб.

06.10.2023    35439    90    40    

112

Инструментарий разработчика Программист 1С:Предприятие 8 Платные (руб)

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

9500 руб.

17.05.2024    49663    172    63    

206

Инструменты администратора БД Инструментарий разработчика Роли и права Программист 1С:Предприятие 8 1C:Бухгалтерия Россия Платные (руб)

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

17000 руб.

10.11.2023    23682    84    42    

99

Разработка Инструментарий разработчика Работа с интерфейсом Адаптация типовых решений Нейросети 1C:Бухгалтерия 1C:ERP 1С:ЗУП 1С:КА 1С:УНФ 1С:УТ 1С:Розница 1С:ДО 1С:ERP Управление предприятием 2 Платные (руб)

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

36600 руб.

28.08.2025    6397    2    2    

6
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. script 128 25.11.15 20:32 Сейчас в теме
Ничего не понял. А накой это нужно?
delete; roofless; +2 Ответить
3. Ibrogim 1478 26.11.15 08:39 Сейчас в теме
(1) script,
А накой это нужно?

Например есть модуль для получения данных через com и не через com . Чтобы не поддерживать одновременно два модуля, можно воспользоваться этим инструментом
2. Ibrogim 1478 26.11.15 08:34 Сейчас в теме
Круто. Однако непонятно, почему бы просто поиском и заменой не убрать "ДругаяБаза." и подобные вещи?

Вопрос снимается, увидел
без дублирования кода.
mikhailv; +1 Ответить
4. LsrGroup 01.12.15 16:43 Сейчас в теме
Проще код писать во внешней обработке, и вызывать ее как через COM, так и напрямую.
6. mikhailv 20 01.12.15 21:15 Сейчас в теме
(4) LsrGroup, указанный Вами подход имеет право на жизнь. Но Вы ведете речь о коде, который еще не написан, а здесь речь об уже существующем коде, написанном с com-коннектором и обращениями вида ДругаяБаза.NewObject, ДругаяБаза.Справочники и т.д. Хотелось сохранить один вариант кода без существенной переработки, реализовав работу как с com, так и без.

(5) Yashazz, 1) без com-коннектора быстрее. 2) com не доступен в linux
Светлый ум; +1 Ответить
5. Yashazz 4901 01.12.15 17:26 Сейчас в теме
Так а что мешало запустить сеанс текущей базы из себя самой по com-коннектору?
7. tormozit 7337 02.12.15 01:20 Сейчас в теме
Тоже сталкивался с такой проблемой много раз. Уже давно попросил 1С сделать такое свойство глобального контекста https://partners.v8.1c.ru/forum/t/574489/m/574489, но не был услышан.
Как правильно заметил LsrGroup, одним из вариантов решения проблемы будет написание кода во внеших обработках, но это накладывает ряд ограничений, например на сложность кода и невозможность его использования в тонком клиенте. Мы довольно широко применяем такой подход в нашем продукте 2iS:Интеграция.
Светлый ум; +1 Ответить
Для отправки сообщения требуется регистрация/авторизация