gifts2017

Запуск внешнего отчета (обработки) из командной строки.

Опубликовал Алексей Выхрыстюк (avhrst) в раздел Администрирование - Сервисные утилиты

Запуск внешнего отчета (обработки) из командной строки.

Столкнулся с необходимостью запустить внешнюю обработку без открытия 1С из командной строки. Изучение пакетного режима запуска 1С (77) закончилось безрезультатно. Разработал .exe файлик для запуска внешнего отчета 1С из командной строки.

Принцип действия OpenForm.exe:

  1. Открываем в фоновом процессе базу через OLE.
  2. Запускаем из базы ОткрытьФорму().

Описание параметров можно получить набрав в командной строке c:\OpenForm.exe ?

P.S. Для работы необходим Microsoft .NET Framework 1.0 и 2.0

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

Наименование Файл Версия Размер
- 246
.1198671550 28,00Kb
25.09.09
246
.1198671550 28,00Kb Бесплатно

См. также

Подписаться Добавить вознаграждение
Комментарии
1. Андрей (andrewalexk) 26.12.07 17:03
2. Сhe Burashka (CheBurator) 26.12.07 18:21
(1) жжожь нереально...
предлагаю на номинанта "гланды через ЗПС"
3. it.net (avhrst) 26.12.07 18:41
Не понимаю критики, если вызывает проблему фраймворк который свободно распространяется Microsoft , плюс во всем мире програмеры переходят на .NET платформу которая требует NF2 а уже и 3,5 - тогда присылайте свое мыло, я вам бедненьким скину :)
4. it.net (avhrst) 26.12.07 18:42
А решить проблему запуска 1С с командной строки ... других способов я не знаю..
5. Сhe Burashka (CheBurator) 26.12.07 20:21
Что значит "без открытия 1С из командной строки"...?
почему нельзя запустить 1С из командной строки с параметрами?
6. Аркадий Кучер (Abadonna) 26.12.07 22:08
Все вопросы решаются добавлением в процедуру ПриНачалеРаботыСистемы()
единственной строчки
ОткрытьФорму("Отчет",,КаталогИБ()+"Старт.ert");
А уж в нем запущай что хошь и как хошь
7. it.net (avhrst) 27.12.07 00:20
Abadonna - очень грамотное решение, особенно если речь идет о 100 типовых конфигурациях, а когда обновление выйдет - стрелятся ! Плюс не забывайте что процедура ПриНачалеРаботыСистемы() срабатывает и тогда когда в базу входит юзер, а в данном случае обработку запускать не надо .

8. it.net (avhrst) 27.12.07 00:23
Сhe Burashka - а не могли бы Вы привести в коментариях пример запуска внешней обработки из 1С с помощью командной строки ?
9. Аркадий Кучер (Abadonna) 27.12.07 00:33
>Плюс не забывайте что процедура ПриНачалеРаботыСистемы() срабатывает и тогда
Ну, блин, разжевываю. В Старт.ert
Код
Процедура ПриОткрытии()
   Если ИмяПользователя()<>"Автопилот" Тогда
      СтатусВозврата(0);
      Возврат;
   КонецЕсли; 
   // а тут ля-ля тополя запускаем, что хотим, хоть 100 обработок
КонецПроцедуры
Показать полностью

10. Аркадий Кучер (Abadonna) 27.12.07 00:37
А 100 ьтповых - это, конечно, круто!!!
А в 3-5 вставить одну строчку - никаких проблем не вижу
11. it.net (avhrst) 27.12.07 00:39
Abadonna - модуль красивый, но мне надо чтобы все действия которые выполняет внешняя обработка имели автора (имя пользователя указывается в командной строке), плюс для глухих КОНФИГУРАЦИЙ 100 И ВСЕ ТИПОВЫЕ И МЕНЯТЬ ИХ НЕЛЬЗЯ
12. it.net (avhrst) 27.12.07 00:43
Abadonna - и еще вопрос, например тебе надо в типовую конфигурацию из MS Excel затащить данные, и чтобы автор документа был, и чтобы юзер в Excel выставлял период, нажимал в екселе кнопку и в 1С появлялся документ (например) с его именем ? (а конфигураций у меня не 100 , а 160 и все типовые :))
13. it.net (avhrst) 27.12.07 00:45
Кстати очень часто возникают ситуации когда когда неизвесно какую обработку придется запустить, и с какими параметрами ..
14. it.net (avhrst) 27.12.07 00:59
Abadonna - А с заставкой 1С что будеш делать ? (если не корявить библиотеки, то заставка не отображается только в режиме запуска через OLE)
15. Аркадий Кучер (Abadonna) 27.12.07 01:21
А тебе говорил про запуск обработок, которые у меня по ночам работают: синхронизации всякие и т.д.
Там мне по барабану заставки и прочее. А так... я просто не могу себе представить ситуёвину, когда конкретному юзверю надо "втихую" запустить внешний отчет.
16. it.net (avhrst) 27.12.07 01:26
Вот тебе ситуация - двухсторонний обмен с Oracle, в 1С бухгалтера сидят, в oracle остальные отделы, а документами менятся надо и автор документа должен быть. Сидит себе человек работает в 1С, а тут заставка появляется , круто ?!!
17. it.net (avhrst) 27.12.07 01:28
Я бы ввобще все через OLE делал (документы создавал, справочники) но 1С с OLE мягко выражаясь работает плохо..
18. Аркадий Кучер (Abadonna) 27.12.07 01:36
А насчет запуска 1С командной строкой с передачей параметра внешнего отчета Чебурашка, мягко говоря, загнул.
Не предусмотрено
19. it.net (avhrst) 27.12.07 01:39
Если б было предусмотрено, я бы с экзешником не возился..
20. Аркадий Кучер (Abadonna) 27.12.07 01:43
Ну я ж и не утверждал, что твой вариант плохой ;)
Просто мне, например, он САВСЭМ без надобности. Для твоих конкретных условий - наверное самый правильный.
21. it.net (avhrst) 27.12.07 01:46
Выставил, может кому надо, а то я 2 дня с пакетным режимом т..ся :)
22. Аркадий Кучер (Abadonna) 27.12.07 01:51
Ха! Мой предок под Винницей родился :))) почти земляки
23. Сhe Burashka (CheBurator) 27.12.07 03:17
АвторУ: посмотри внимательно на Абадонновский Автопилот.
Запусти под АВТОПИЛОТОМ отдельный экземпляр 1Сины - и пусть ОН НАРУЖУ ВЫДАЕТ ДАННЫЕ КАК ХОЧЕТ.
А запуск любого внешнего отчета не изменяя код конфигурации - НИ ОДНОЙ СТРОКИ и ни разу - я думаю, что можно извратиться.. мысль есть но) 1.моих познаний пока недостаточно 2. ЭТО БУДЕТ ЕЩЕ ОДНА ОФИГЕННАЯ ДЫРКА!!!
как пример запуска любой внешней обработки из командной строки
1. разобрать конфигурацию, извне подправить текст, собрать конфигурацию и запустить, после выхода из проги - снова разобрать, удалить следы внедренного кода и собрать...
.. это будет намного дешевле чем вставить в конфигурацию старт.ert?
если старт.ert надо вставить в 100 конфиг единовременно один раз чтобы использовать потом - решается выше аналогично...
2. запустить через командную строку 1Сину обычным образом и сэмуоировать в ее окно команды меню-файл-открыть...
24. Сhe Burashka (CheBurator) 27.12.07 03:20
а чего, по ОЛЕ нельзя ОткрытьФорму() штатную сделать? - очень сомневаюсь...евал попробовать Шаблон попробовать
25. it.net (avhrst) 27.12.07 09:45
Сhe Burashka - так я и открываю через OLE ОткрытьФорму() штатными средствами, и вообще стоит четкая задача - запуск внешнего отчета с передачей параметров из командной строки Windows - тоесть из любого приложения.
26. it.net (avhrst) 27.12.07 09:53
OpenForm.exe занимает 28Kb, так как кроме консольного приложения в нем больше ничего не используется, то скорей всего он будет работать и без 2.0 фраймворка (попробовать негде).
27. Aikosyapr (aikosyapr) 07.08.08 12:43
Большое спасибо автору, именно то, что нужно и нигде ничего похожего кроме кривой ert2exe не нашёл
28. Александр Елкин (VladAlex) 16.03.09 15:19
Автору, конечно, спасибо, но я не пока не осилил. Буду благодарен, если кто-то добрый ткнет меня носом в ошибку.

Во внешней обработке пишу такой код:
Процедура ПриОткрытии()
ЛогДок=СоздатьОбъект("Текст");
ЛогДок.ДобавитьСтроку("ПриОткрытии().Start");
Если ТипЗначенияСтр(Форма.Параметр) = "Строка" Тогда
Сформировать(2,Форма.Параметр);
СтатусВозврата(0);
КонецЕсли;
ЛогДок.ДобавитьСтроку("ПриОткрытии().End");
ЛогДок.Записать("c:\log.txt");
КонецПроцедуры

При ручном запуске данный код создает лог файл, а через openForm.exe - нет.
Листинг запуска openForm:
============================================================­===
C:\Бухгалтерия\ExtForms>openForm.exe c:\Бухгалтерия\ Автопилот
123 C:\Бухгалтерия\ExtForms\Export_20090308_155054.xml transfer.ert
Получены параметры: 16.03.2009 21:01:02
Путь к базе: c:\Бухгалтерия\
Поьлзователь: Автопилот
Пароль: 123
Параметр: C:\Бухгалтерия\ExtForms\Export_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
============================================================­===

29. Александр Елкин (VladAlex) 17.03.09 12:30
(28) Примерно понимаю где главная ошибка - поведение не изменяется, если указывать несуществующие файлы обработки. Т.е. openForm не находит мою обработку. Попробовал указывать полный путь к обработке, перемещал ее в корень диска, но безуспешно. Остальные параметры воспринимаются правильно, т.к. если, например, не указать пароль пользователя, то появляется диалог ввода пароля.
30. irisha (irisha) 12.02.10 10:02
А как открыть эту обработку, чтобы подправить под свои нужды?
31. Павел (PavelTLT) 08.04.10 15:58
Прекрасная вещица!
У меня тоже не сразу заработала.
Оказывается, я забыл из базы выйти (сидел под тем же юзером, под которым пытался запустить).

Автору спасибо!
32. Максим Я (maxchaos) 08.02.11 15:00
Спасибо! +1!
Если не сложно, просьба создать второй вариант файла для запуска 1С в монопольном режиме. Тогда, если название второго exe-файла задать типа "openFormMono.exe", то можно будет использовать оба варианта сабжа, при необходимости, динамически моделируя имя запускаемого файла.
34. Сергей Лунев (luns) 08.02.11 16:10
Параметры командной строки для указания параметров запуска

/Execute <имя файла внешней обработки> — предназначен для запуска внешней обработки в режиме 1С:Предприятие непосредственно после старта системы.
35. Сергей Лунев (luns) 08.02.11 16:12
ой. не заметил. тут семерошники тусят.
как у них все сложно :D
36. Ийон Тихий (cool.vlad4) 08.02.11 16:15
(32) reflector в руки и вперед. Можно было вообще скриптом сделать. Хоть на том же c#. Хотя необходимости в net-е здесь не вижу- консольную программку можно сделать на чем угодно.
37. Сергей (Che) Коцюра (CheBurator) 08.02.11 16:19
(35) не всем же деревням в 10 двров нужны камазы съездить в сельпо... ;-)
38. 123 123 (TBAPb23) 31.05.12 16:59
Спасибо, очень пригодилось. Отличное решение для тех у кого типовая конфигурация.