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

25.11.15

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

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

Файлы

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

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

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

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

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

Вы можете заказать платную доработку или адаптацию этой разработки под вашу конфигурацию на «Бирже заказов».

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.

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

Далее привожу в сравнении идентичные синтаксически конструкции для 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    66149    349    163    

307

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

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

16500 руб.

02.09.2020    256421    1417    421    

1160

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

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

15250 руб.

25.08.2025    52456    106    29    

117

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

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

22570 руб.

06.10.2023    37627    98    46    

118

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

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

17000 руб.

10.11.2023    24867    92    44    

101

Мастера заполнения Поиск данных Инструментарий разработчика Подбор и обработка объектов 1С 8.3 1С 8.5 Платные (руб)

Infostart MagicInput улучшает подбор в полях ввода 1С: ищет по любой части названия и по нескольким ключевым фрагментам, распознаёт ввод в другой раскладке и показывает иконки/статусы объектов прямо в списке. Поддерживает вставку навигационной ссылки/представления документа для автоподбора; для разработчиков доступны поиск по GUID и полному имени предопределённого. Работает в управляемых формах и подключается в большинстве конфигураций 1С 8.3/8.5.

6000 руб.

25.02.2026    3213    12    1    

14

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

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

9500 руб.

17.05.2024    52276    181    63    

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

Например есть модуль для получения данных через com и не через com . Чтобы не поддерживать одновременно два модуля, можно воспользоваться этим инструментом
2. Ibrogim 1649 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 4915 01.12.15 17:26 Сейчас в теме
Так а что мешало запустить сеанс текущей базы из себя самой по com-коннектору?
7. tormozit 7375 02.12.15 01:20 Сейчас в теме
Тоже сталкивался с такой проблемой много раз. Уже давно попросил 1С сделать такое свойство глобального контекста https://partners.v8.1c.ru/forum/t/574489/m/574489, но не был услышан.
Как правильно заметил LsrGroup, одним из вариантов решения проблемы будет написание кода во внеших обработках, но это накладывает ряд ограничений, например на сложность кода и невозможность его использования в тонком клиенте. Мы довольно широко применяем такой подход в нашем продукте 2iS:Интеграция.
Светлый ум; +1 Ответить
Для отправки сообщения требуется регистрация/авторизация