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

25.11.15

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

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

Файлы

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

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

Подписка 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С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

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

15500 руб.

02.09.2020    218884    1198    413    

1059

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

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

14400 руб.

20.08.2024    44225    244    123    

226

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

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

22200 руб.

06.10.2023    27801    73    30    

101

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

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

9500 руб.

17.05.2024    39626    143    57    

182

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

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

9900 руб.

25.08.2025    10984    17    7    

28

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

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

16000 руб.

10.11.2023    19643    76    39    

92

Инструментарий разработчика WEB-интеграция 1С v8.3 1C v8.2 1C:Бухгалтерия 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Зарплата и Управление Персоналом 3.x Платные (руб)

Инструмент для генерации OpenApi (Swagger) спецификаций на основании файлов конфигураций 1С. Это консольное и десктопное приложение на языке Rust с полноценным редактором кода, содержащим автозамену и подсвечивание ошибок для быстрого и безошибочного написания документирующего комментария.

18000 руб.

22.11.2024    2648    2    0    

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

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