Запуск внешнего отчета (обработки) из командной строки.
Столкнулся с необходимостью запустить внешнюю обработку без открытия 1С из командной строки. Изучение пакетного режима запуска 1С (77) закончилось безрезультатно. Разработал .exe файлик для запуска внешнего отчета 1С из командной строки.
Принцип действия OpenForm.exe:
- Открываем в фоновом процессе базу через OLE.
- Запускаем из базы ОткрытьФорму().
Описание параметров можно получить набрав в командной строке c:OpenForm.exe ?
P.S. Для работы необходим Microsoft .NET Framework 1.0 и 2.0
🙂
«1.0 и 2.0»
жжош!
(1) жжожь нереально…
предлагаю на номинанта «гланды через ЗПС»
Не понимаю критики, если вызывает проблему фраймворк который свободно распространяется Microsoft , плюс во всем мире програмеры переходят на .NET платформу которая требует NF2 а уже и 3,5 — тогда присылайте свое мыло, я вам бедненьким скину 🙂
А решить проблему запуска 1С с командной строки … других способов я не знаю..
Что значит «без открытия 1С из командной строки»…?
почему нельзя запустить 1С из командной строки с параметрами?
Все вопросы решаются добавлением в процедуру ПриНачалеРаботыСистемы()
единственной строчки
ОткрытьФорму(«Отчет»,,КаталогИБ()+»Старт.ert»);
А уж в нем запущай что хошь и как хошь
Abadonna — очень грамотное решение, особенно если речь идет о 100 типовых конфигурациях, а когда обновление выйдет — стрелятся ! Плюс не забывайте что процедура ПриНачалеРаботыСистемы() срабатывает и тогда когда в базу входит юзер, а в данном случае обработку запускать не надо .
Сhe Burashka — а не могли бы Вы привести в коментариях пример запуска внешней обработки из 1С с помощью командной строки ?
>Плюс не забывайте что процедура ПриНачалеРаботыСистемы() срабатывает и тогда
Ну, блин, разжевываю. В Старт.ert
Показать полностью
А 100 ьтповых — это, конечно, круто!!!
А в 3-5 вставить одну строчку — никаких проблем не вижу
Abadonna — модуль красивый, но мне надо чтобы все действия которые выполняет внешняя обработка имели автора (имя пользователя указывается в командной строке), плюс для глухих КОНФИГУРАЦИЙ 100 И ВСЕ ТИПОВЫЕ И МЕНЯТЬ ИХ НЕЛЬЗЯ
Abadonna — и еще вопрос, например тебе надо в типовую конфигурацию из MS Excel затащить данные, и чтобы автор документа был, и чтобы юзер в Excel выставлял период, нажимал в екселе кнопку и в 1С появлялся документ (например) с его именем ? (а конфигураций у меня не 100 , а 160 и все типовые :))
Кстати очень часто возникают ситуации когда когда неизвесно какую обработку придется запустить, и с какими параметрами ..
Abadonna — А с заставкой 1С что будеш делать ? (если не корявить библиотеки, то заставка не отображается только в режиме запуска через OLE)
А тебе говорил про запуск обработок, которые у меня по ночам работают: синхронизации всякие и т.д.
Там мне по барабану заставки и прочее. А так… я просто не могу себе представить ситуёвину, когда конкретному юзверю надо «втихую» запустить внешний отчет.
Вот тебе ситуация — двухсторонний обмен с Oracle, в 1С бухгалтера сидят, в oracle остальные отделы, а документами менятся надо и автор документа должен быть. Сидит себе человек работает в 1С, а тут заставка появляется , круто ?!!
Я бы ввобще все через OLE делал (документы создавал, справочники) но 1С с OLE мягко выражаясь работает плохо..
А насчет запуска 1С командной строкой с передачей параметра внешнего отчета Чебурашка, мягко говоря, загнул.
Не предусмотрено
Если б было предусмотрено, я бы с экзешником не возился..
Ну я ж и не утверждал, что твой вариант плохой 😉
Просто мне, например, он САВСЭМ без надобности. Для твоих конкретных условий — наверное самый правильный.
Выставил, может кому надо, а то я 2 дня с пакетным режимом т..ся 🙂
Ха! Мой предок под Винницей родился :))) почти земляки
АвторУ: посмотри внимательно на Абадонновский Автопилот.
Запусти под АВТОПИЛОТОМ отдельный экземпляр 1Сины — и пусть ОН НАРУЖУ ВЫДАЕТ ДАННЫЕ КАК ХОЧЕТ.
А запуск любого внешнего отчета не изменяя код конфигурации — НИ ОДНОЙ СТРОКИ и ни разу — я думаю, что можно извратиться.. мысль есть но) 1.моих познаний пока недостаточно 2. ЭТО БУДЕТ ЕЩЕ ОДНА ОФИГЕННАЯ ДЫРКА!!!
как пример запуска любой внешней обработки из командной строки
1. разобрать конфигурацию, извне подправить текст, собрать конфигурацию и запустить, после выхода из проги — снова разобрать, удалить следы внедренного кода и собрать…
.. это будет намного дешевле чем вставить в конфигурацию старт.ert?
если старт.ert надо вставить в 100 конфиг единовременно один раз чтобы использовать потом — решается выше аналогично…
2. запустить через командную строку 1Сину обычным образом и сэмуоировать в ее окно команды меню-файл-открыть…
а чего, по ОЛЕ нельзя ОткрытьФорму() штатную сделать? — очень сомневаюсь…евал попробовать Шаблон попробовать
Сhe Burashka — так я и открываю через OLE ОткрытьФорму() штатными средствами, и вообще стоит четкая задача — запуск внешнего отчета с передачей параметров из командной строки Windows — тоесть из любого приложения.
OpenForm.exe занимает 28Kb, так как кроме консольного приложения в нем больше ничего не используется, то скорей всего он будет работать и без 2.0 фраймворка (попробовать негде).
Большое спасибо автору, именно то, что нужно и нигде ничего похожего кроме кривой ert2exe не нашёл
Автору, конечно, спасибо, но я не пока не осилил. Буду благодарен, если кто-то добрый ткнет меня носом в ошибку.
Во внешней обработке пишу такой код:
Процедура ПриОткрытии()
ЛогДок=СоздатьОбъект(«Текст»);
ЛогДок.ДобавитьСтроку(«ПриОткрытии().Start»);
Если ТипЗначенияСтр(Форма.Параметр) = «Строка» Тогда
Сформировать(2,Форма.Параметр);
СтатусВозврата(0);
КонецЕсли;
ЛогДок.ДобавитьСтроку(«ПриОткрытии().End»);
ЛогДок.Записать(«c:log.txt»);
КонецПроцедуры
При ручном запуске данный код создает лог файл, а через openForm.exe — нет.
===
===
Листинг запуска openForm:
============================================================
C:БухгалтерияExtForms>openForm.exe c:Бухгалтерия Автопилот
123 C:БухгалтерияExtFormsExport_20090308_155054.xml transfer.ert
Получены параметры: 16.03.2009 21:01:02
Путь к базе: c:Бухгалтерия\r
Поьлзователь: Автопилот
Пароль: 123
Параметр: C:БухгалтерияExtFormsExport_20090308_155054.xml
Путь к внешнему отчету: transfer.ert
Подключение к 1С … 16.03.2009 21:01:02
Подключено. 16.03.2009 21:01:05
Запуск обработки….16.03.2009 21:01:05
Обработка завершена.16.03.2009 21:01:05
============================================================
(28) Примерно понимаю где главная ошибка — поведение не изменяется, если указывать несуществующие файлы обработки. Т.е. openForm не находит мою обработку. Попробовал указывать полный путь к обработке, перемещал ее в корень диска, но безуспешно. Остальные параметры воспринимаются правильно, т.к. если, например, не указать пароль пользователя, то появляется диалог ввода пароля.
А как открыть эту обработку, чтобы подправить под свои нужды?
Прекрасная вещица!
У меня тоже не сразу заработала.
Оказывается, я забыл из базы выйти (сидел под тем же юзером, под которым пытался запустить).
Автору спасибо!
Спасибо! +1!
Если не сложно, просьба создать второй вариант файла для запуска 1С в монопольном режиме. Тогда, если название второго exe-файла задать типа «openFormMono.exe», то можно будет использовать оба варианта сабжа, при необходимости, динамически моделируя имя запускаемого файла.
Параметры командной строки для указания параметров запуска
/Execute <имя файла внешней обработки> — предназначен для запуска внешней обработки в режиме 1С:Предприятие непосредственно после старта системы.
ой. не заметил. тут семерошники тусят.
как у них все сложно 😀
(32) reflector в руки и вперед. Можно было вообще скриптом сделать. Хоть на том же c#. Хотя необходимости в net-е здесь не вижу- консольную программку можно сделать на чем угодно.
(35) не всем же деревням в 10 двров нужны камазы съездить в сельпо… 😉
Спасибо, очень пригодилось. Отличное решение для тех у кого типовая конфигурация.
Разобрался. Супер!! Спасибо!!!!