Фишечки-рюшечки

За годы работы с 1С собрался определенный багаж хитростей, который позволяет разрабатывать быстрее/эффективнее/качественнее. Поделюсь ими в данной статье.

Для начала немножко архитектурных решений…

Использование справочника с предопределенными объектами вместо НайтиПоНаименованию

Буквально на днях столкнулся с тем, что для кого-то такой подход является откровением, поэтому опишу его здесь. Итак, если необходимо в коде получить доступ к какому-то элементу справочника, то решение в лоб — использовать методы НайтиПоНаименованию и НайтиПоКоду. У данных методов есть один большой недостаток — изменение кода или наименования привод к неработоспособности механизма. А в типовых конфигурациях к тому же не всегда есть код у элемента справочника. Поэтому данный способ подходит для каких-то одноразовых обработок, а не механизма в целом.

Чтобы сделать более универсально, создаем справочник. Назовем его, например, "Настройки". У справочника создаем один реквизит — "Значение". Тип реквизита составной, отмечаем примитивные типы и "Любая ссылка". Теперь, чтобы хранить какое-то значение, создаем предопределенный элемент этого справочника. Назовем его, например, "ТипНоменклатуры". В нем мы будем хранить ссылку на тип номенклатуры, с которым по коду будем что-нибудь делать. В режиме предприятия в этот элемент справочник проставим значение — наш особенный тип номенклатуры. Далее, в режиме конфигуратора обращаемся как Справочники.Настройки.ТипНоменклатуры.Значение. Тут и будет наша ссылка на тип номенклатуры. Недостатки данного подхода

  • невозможность работать с расширениями (не создаются предопределенные элементы);
  • если получаем тип булево, то необходимо обязательно явно проверять его на истину (Если Справочники.Настройки.ИспользоватьНовыйМеханизм.Значение = Истина Тогда) потому, что если не задать значение в режиме предприятия, то значение будет Неопределено.

Если надо через расширение, то можно попробовать сделать такой фокус через регистр сведений.

Дополнительная роль

Как часто у вас бывало, что кодите какой-то супер механизм, протестили, все замечательно, накатываете на продакшн, приходите к директору демонстрировать и… Недостаточно прав для работы с таблицей РегистрСведений.КурлыкКурлык. "А кто же будет тестировать под правами директора?" — скажете вы, но тут же вспомните пару таких же своих косяков в прошлом месяце. Ок, сам неумный, надо было тестировать, но что дальше-то делать? Всех выгонять? Динамическое обновление? Прийти завтра? 

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

Ну и недостатки, как же без них:

  • Необходимо периодически вручную убирать доступ у этой роли к уже исправленным в продакшене метаданным;
  • Необходимо мониторить, чтобы эта роль была включена у пользователя только тогда, когда это нужно;
  • Неудобно использовать, если ломается не у единичных пользователей, а у основной массы.

Ну и немного хитростей при работе с конфигуратором

  • Удивительно, но далеко не все знают, что глобальный поиск можно остановить сочетанием клавиш Ctrl+Break. Правда, в версиях около 8.3.12 работает с перебоями.
  • Чтобы поставить знак & — необязательно переключаться на английскую раскладку! Просто зажмите кнопку Alt и на NUM-клавиатуре наберите 38. Отпустите Alt. Alt+35 дает знак решетки. Хотите узнать больше сочетаний — загуглите Alt символы. Я пока выучил только эти две комбинации
  • Не можете найти какая форма открывается по ссылке где-нибудь в интерфейсе? Делается это легко, подготавливаем в режиме предприятия окна так, чтобы первое нажатие на ссылку/кнопку/поле делало именно то, что мы не можем найти. В режиме конфигуратора в меню Отладка нажимаем Остановить. Бежим в режим предприятия, пока не вывалились в обработчик ожидания, и жмем эту ссылку/кнопку/поле. В итоге мы оказываемся в точке останова в первой же строке, которая выполняется по событию нажатия. В новых конфигурациях, зачастую, этой первой строкой становится проверка на резервное копирование, которая подвязана на обработчик ожидания.
  • Если отлаживаете большой кусок кода с ветвлениями и не хотите пошагово идти по коду, чтобы понять, какие условия отрабатывают — включите замер производительности. Рядом со строками, которые исполнялись будет стоять время.
  • Для отладки фоновых заданий в типовой конфигурации можно либо в меню подключений установить автоматическое подключение фоновых заданий, либо запускать отладку с ключом РежимОтладки. В последнем случае все фоновые задания будут запускаться в текущем сеансе.
  • Уже давно в конфигураторе есть возможность подсвечивать слова, которые совпадают со словом под курсором, но почему-то по умолчанию подсвечивается белым цветом, т.е. вообще не подсвечивается. Исправляем!
     

Надеюсь, статья будет кому-то полезной!

93 Comments

  1. Hans

    Есть какие нибудь решения что бы при «Отладка» > «Остановить» не ловило обработчики ожидания?

    Reply
  2. myxins1989

    (1) Ну как вариант отловить, где он включается и закомментить. Другие не искал. Если сильно надо было, то просто сворачивал окна таким образом, чтобы можно было максимально быстро нажать на кнопку в режиме предприятия.

    Reply
  3. VmvLer

    спасибо статья очень полезная — я заново открыл для себя мир 1С и мощь конфигуратора.

    Reply
  4. FesenkoA
    Использование справочника с предопределенными объектами вместо НайтиПоНаименованию

    Поздравляю, вы изобрели регистр сведений свойства объектов!

    Reply
  5. myxins1989

    (4)

    вы изобрели регистр сведений свойства объектов!

    Про какой регистр речь? Где посмотреть его структуру? В типовых такой не вижу

    Reply
  6. myxins1989

    (3) Написал то, что сразу вспомнилось, либо с чем каждый день имею дело. Сейчас буду записывать более редкие фишки, как наберутся, еще одну статью накидаю.

    Reply
  7. FesenkoA

    (5) К сожалению, 1С изобрел его обратно с переходом на управляемые формы… Раньше был такой регистр, в нем было измерение объект ИБ (ссылка), свойство (ПВХ) и ресурс — значение (любой тип), и используя пустой объект, можно было при помощи ПВХ указать свойство и использовать как «динамические константы»..

    Reply
  8. Cерый

    Alt-251 √

    Alt-252 №

    Alt-124 | для запросов в коде и другая псевдографика Alt-176 — Alt-223:

    //┌───────────────────────╖

    //│ Служебные процедуры ║

    //╘═══════════════════════╝

    Reply
  9. vcv
    далеко не все знают, что глобальный поиск можно остановить сочетанием клавиш Ctrl+Break.

    А ещё не все производители клавиатур и ноутбуков знают, что кому-то может понадобится такое сочетание клавиш. И в терминале Ctrl+Break как-то загадочно может работать…

    Reply
  10. myxins1989

    (9) Это скорее просто глюк платформы, начиная с 8.3.10 вроде как стали замечать такое поведение, в 8.3.15 работает нормально. Иногда, чтобы сработало, надо выбрать любое другое окно, потом в панели задач выбрать подвисшее окно конфигуратора. Иногда и это не помогает. У меня на ноуте получается сочетание Ctrl+Fn+Pause

    Reply
  11. Papilion

    У нас такой справочник называется «Внешние предопределенные» и получаем реквизиты не напрямую, а через методы, чтобы избежать вашей ситуации с булевом. Роль называется «Новые объекты по умолчанию», очень выручает когда запаришься и забудешь сделать роль пользователю. А еще я использую ALT + 60, ALT +62 для знаков < >.

    Reply
  12. Dream_kz
    если необходимо в коде получить доступ к какому-то элементу справочника, то решение в лоб — использовать методы НайтиПоНаименованию и НайтиПоКоду

    А можно через ПолучитьСсылку() по гуиду, 100% получим то, что надо

    Reply
  13. myxins1989

    (12) Можно, но зашивать гуид в конфу тоже не совсем правильно. А если не зашивать, то его опять таки надо где-то хранить, куда можно однозначно попасть из-под конфигуратора.

    Reply
  14. DarkAn

    Мне больше нравиться

    F12 в сочетании с Ctrl+»-« (назад) и Ctrl+Shift+»-« (вперед)

    где «-» — минус на основной клавиатуре 🙂

    Reply
  15. krava_vlad

    С предопределеными элементами не согласен. При глюках РИБ предопределеные элементы задваеваются и тогда молись чтоб запустились риб-база в режиме предпиятия

    Reply
  16. pm74

    (0)

    Использование справочника с предопределенными объектами вместо НайтиПоНаименованию

    подобные решения уже неоднократно обсуждались на ИС , подходы различаются лишь в мелочах. например мне удобнее хранить в таком справочнике н е только (условные) константы , но и соответствия

    Reply
  17. user705698_bursev

    Добрый день.

    Понравилась идея с дополнительной ролью.

    Но это получается, что ее нужно периодически вручную чистить от добавленных объектов. И, если забыть это сделать, то в один прекрасный день, у такого пользователя, кому эта роль будет добавлена, окажется очень много лишних прав.

    Reply
  18. myxins1989

    (17) Ну как правило она выдавалась директорам, руководителям, их не так уж и много. А в грязь лицом перед ними упасть приятного мало 🙂

    Reply
  19. myxins1989

    (15) Вся суть в том, что для них создается отдельный справочник, а не используются предопределенные элементы в типовых справочниках. Хотя, мы не использовали такое в рибе.

    Reply
  20. myxins1989

    (16) Такие вещи видимо надо периодически писать, чтобы новенькие видели, а не догадывались сами. Плюс, если горячие клавиши или режим отладки для фоновых заданий легко загуглить, то такое даже в голову не придет гуглить.

    Reply
  21. myxins1989

    (11)

    У нас такой справочник называется «Внешние предопределенные» и получаем реквизиты не напрямую, а через методы, чтобы избежать вашей ситуации с булевом. Роль называется «Новые объекты по умолчанию», очень выручает когда запаришься и забудешь сделать роль пользователю. А еще я использую ALT + 60, ALT +62 для знаков .

    Я прям как в зеркало посмотрел 🙂 А как насчет Ctrl+T?

    Reply
  22. Sashares

    (3)Вы табличку «Сарказм» вставляйте, а то не всегда понятно, где вы пишите серьезно.

    Reply
  23. FesenkoA

    (8)

    Reply
  24. Shmell

    (10) Есть такая вещь как виртуальная клавиатура. Вот на ней есть Break.

    Reply
  25. Darklight

    Дежавю… Где-то я это всё уже видел….

    Reply
  26. myxins1989

    (25) Суть комментария?

    Reply
  27. iliabvf

    За подсветку конечно спасибо, наконец-то мы догнали 2003 год

    Reply
  28. Papilion

    (17)Роль чистить не надо, это своего рода временный админ, ты ее выдаешь только тогда когда не предусмотрел что-то в своей роли, а после всех настроек забираешь. Еще помню открытием было CTRL + T в конфигураторе, чтобы перейти на объект который открыт.

    Reply
  29. buganov

    В секции поиск по наименованию лучше уж либо:

    а) добавить в справочник реквизит ИмяДляПоиска, формировать его перед первой записью и уже его использовать. И изменение кодов и наименований не страшно. Так, кстати, сделано в последних типовых для ПВХ дополнительныеРеквизитыИСведения.

    б) создать регистр сведений Структурой: Свойство(Измерение, Тип(ПВХ)) — Значение(Ресурс)

    Про дополнительную роль. Есть мина замедленного действия — если пользователю не следует видеть какой то тип документов, то с этой ролью он все прекрасно увидит и, скорее всего, сможет даже чего-то наизменять.

    Кстати, хорошим правилом является создание двух ролей для каждого создаваемого объекта — на чтение и просмотр/редактирование. Можно, конечно и на изменение отдельную роль, но не припомню, когда такое было бы нужно.

    Reply
  30. Sashares

    (26)Суть в том, что все что в статье жуткий баян, и эта информация есть в куче других статей. Если вы думаете, что открыли Америку, то напрасно.

    Reply
  31. myxins1989

    (30) Для кого-то баян, для кого-то нет. Непонятно, для чего комментарий писать? Показать свой исключительный ум и начитанность? Мне тоже много статей здесь на инфостарте баяном кажутся. У всех разная подготовка. Для кого-то открыл, для кого-то нет.

    Reply
  32. kuzyara
    запускать отладку с ключом РежимОтладки

    Это параметр запуска для БСП.

    Приложение 3. Доступные параметры запуска приложения

    Параметры запуска передаются через ключ командной строки /C<передаваемые параметры> или указываются в конфигураторе в поле Параметр запуска закладки Запуск 1С:Предприятия в меню Сервис – Параметры. Одновременно можно указывать сразу несколько параметров запуска, разделяя их символом «;».

    Например – РежимОтладки; ЗапуститьОбновлениеИнформационнойБазы

    Ниже описаны параметры запуска, предоставляемые библиотекой:

    В я уж думал недокументированная фича…

    5. РежимОтладки.

    Упрощает отладку кода. В частности:

    ● все длительные операции выполняются сразу, без запуска фонового задания;

    ● при разработке расширений конфигурации, возможен запуск с установленными расширениями конфигурации, которые в данный момент открыты в конфигураторе (при условии, что версия конфигурации и версии расширений не менялись).

    Reply
  33. myxins1989

    (29) А если поменяется логика работы? Например, раньше автоматически перемещение создается с одного склада, а тут решили создавать с другого склада. Лезть в код? Для ВторичногоСклада указывать имя для поиска — ОсновнойСклад?

    Reply
  34. lmnlmn

    По первым двум частям статьи. Все это знакомо. Но вот доколе мы будем костылять и забывать что-то там в ролях а то и логике и коде? Непрофессионально это все выглядит, как ни оправдывай. Проектирование, разработку и тестирование надо совершенствовать и отлаживать.

    Reply
  35. myxins1989

    (34)

    Но вот доколе мы будем костыля

    Не ошибается тот, кто ничего не делает. А если нет тестировщика, которому надо платить дополнительные деньги и который тоже может пропустить ошибки, то тестировщиком выступает конечный пользователь. Ответ на вопрос «доколе» — пока кодим. Профессионализм здесь не при чем.

    Reply
  36. lmnlmn

    (35) Понимаю что несколько передергиваю, но услышав от врача «не ошибается тот, кто ничего не делает» как-то стремно иметь с ним дальше дело. Да, мы тут в одно жало копаем весьма сложные системы, прям герои, инженеры, новаторы (хотя бы велоноваторы). Все это, вроде бы как, оправдывает возможность ошибки. Но ведь круто было бы без ошибок и косяков решения сдавать? А для этого надо либо все четко продумать и закодить, либо проверить. Лучше и то и другое. А когда случаются всякие неурядицы с нашими разработками, то выглядим как-то не очень в глазах клиента. Да, к стати, сами же в тестировщиках у 1С сидим. Приятно?

    Reply
  37. l_men

    «[» — Alt + 91,

    «]» — Alt + 93

    тоже достаточно удобно и очень часто используется. Для того что бы запомнить распечатал себе маленькую табличку с символами, которые достаточно часто употребляются в коде и для которых необходимо переключать раскладку. Табличка не больше размера бумажки для записей и прикрепил себе скотчем на монитор). Так же собрал себе небольшой файлик с шаблонами кода, который кочует со мной от проекта на проект.

    Reply
  38. myxins1989

    (37) про шаблоны я уж не стал писать, каждый приходит к этому с годами. Я уже после года работы про них знал, но начал пользоваться совсем недавно, когда выделились какие-то участки кода, которые не обернуть в процедуры и при этом надо часто вызывать.

    Reply
  39. l_men

    (38) Я это делаю для того что бы не искать и не вспоминать некоторые вещи, например когда нужно сделать загрузку из файла Excel просто тащишь код из шаблона. Подставляешь номера колонок и реквизиты) Для примера — открытие файла Xml

    ПослеВыбораФайла = Новый ОписаниеОповещения(«ПослеВыбораФайла», ЭтотОбъект, ИндексЭлемента);
    ДиалогВыбора = Новый ДиалогВыбораФайла(РежимДиалогаВыбораФайла.Открытие);
    ДиалогВыбора.Фильтр = «Файлы xml (*.xml)|*.xml»;
    ДиалогВыбора.Показать(ПослеВыбораФайла);
    
    Reply
  40. myxins1989

    (39) Надо бы тоже так сделать

    Reply
  41. buganov

    (33) Ни первый, ни второй вариант не подразумевает «лезть в код». Наоборот устанавливаете значения в Справочнике или, что больше подходит логике Вашей задачи, в регистре.

    Кто мешает создать в регистре констант константы «Первичный склад», «Вторичный склад»?

    И если меняется логика, то она должна либо меняться в купе с архитектурой, либо интегрируясь в существующую. На регистре можно сварганить очень гибкую систему, логичную, простую в использовании, без необходимости обновления и без колхоза.

    Reply
  42. buganov

    (35)если нет тестировщика, то можно использовать автоматизированные тесты.

    Профессионализм как раз и заключается в неиспользовании костылей, а разработке слаженного и оттестированного механизма.

    Reply
  43. myxins1989

    (41) Т.е. создаем регистр с измерением типа строка, ресурсом типа любая ссылка и примитивные данные. Добавляем туда данные, в конфигураторе по стрлке делаем поиск, получаем значение ресурса. Так?

    Reply
  44. myxins1989

    (42) Это не костыль, а план Б. Много тестов написали? Сколько времени ушло на написание покрывающих тестов? Сколько времени уходит на корректировку тестов с учетом изменения функционала? Во франче работаете или у конечного клиента?

    Reply
  45. buganov

    (43)Измерение типа ПланыВидовХарактеристик.ДополнительныеКонстанты

    Ресурс — любая ссылка, Дата, Булево, Строка(900), Число

    Reply
  46. buganov

    (44)это костыль.

    Несколько особо критичных и на банальное открытие форм и записей объектов под разными пользователями написал.

    Если все сделать правильно, то корректировка не потребуется. Интерфейсы внешние, задействуются механизмы автоматики бизнес-процессов.

    На базе 1С:Тест-центр можно рисовать отличные примитивные тесты. В обработчиках просто вызывать те же механизмы, которые задействуются во время работы пользователя или автоматики. Для более крутых тестов можно использовать ванессу

    У конечного.

    П.С. Если бы я увидел от франча РольНаВсеСлучаиЖизни, то поставил бы вопрос о том, что нужно срочно менять франч.

    Бэкдоры не являются плохим тоном, бывает, выручают очень, но они не должны простым пользователям открывать взору то, что видеть им не положено.

    Reply
  47. myxins1989

    (45) А элемент ПВХ подбирать по наименованию в коде?

    Reply
  48. myxins1989

    (46) Открытие нескольких форм? Которые не разрабатываются? Обработчики форм тоже не вызвать просто так, нужно, чтобы процедуры были экспортные, при типовой разработке это проблематично. Спасибо за обзор возможных программ, я их знаю. А почему не сделаны полностью покрывающие тесты? Может причина в том, что руководству нужен функционал, а не тесты, которые «вы вообще-то сами можете вручную сделать после разработки»?

    К тому же роль не является бекдором, нужно держать эту роль в актуальном состоянии, периодически чистить. И я там указал, что это как правило дается не всем пользователям, а директорам. Как правило в новых объектах нет критичных данных вроде платежек, реализаций, поступлений и прочее. Но вам уже ничего не доказать, вы будете искать причины не использовать этот метод, даже когда он вам бы пригодился. Дальнейшее общение по этому поводу считаю бессмысленным.

    ПС

    Не засиживайтесь на одном проекте/клиенте, мозг атрофируется, проверено.

    Reply
  49. buganov

    (47)Запросом по имени допконстанты. Если кто то изменил ее имя, то того нужно выкидывать на мороз

    Reply
  50. myxins1989

    (49) С таким же успехом можно использовать НайтиПоНаименованию напрямую, а кто поменял имя — выкидывать на мороз.

    Reply
  51. buganov

    (48) Полный прогон ключевых процессов, в том числе открытие форм. Все они должны как минимум открыться.

    Обработчики не тестируем, это в планах и не тест-центром.

    Не сделаны, потому что внедрен ТЦ недавно. Функционал наращивается большим штатом разработчиков, при этом нужен контроль, чтобы при доработке одного механизма не ломался другой. Руководство адекватное и понимает, что новый функционал при сломанном другом хуже, чем полностью рабочая система без нового функционала. И лучше понести затраты на качество тестов, чем затраты на простое системы.

    Я тоже говорю о том, что роль это не бюэкдор, а костыль.

    ПС мозг атрофируется при остановке развития себя, как специалиста, а не засиживании на одном клиенте.

    ПСС. Удачи Вам, не обижайтесь, просто воспримите критику адекватно и сделайте выводы, что есть варианты лучше, чем «ПолныеПрава» в качестве плана Б.

    Reply
  52. buganov

    (50) Вы понимаете разницу между предопределенным элементом, который создается в конфигураторе, требует обновления и только потом использование от служебного регистра, в котором все делается в пользовательском режиме, создается, изменяется, удаляется. Прямо на лету. Можно даже исключения втыкать в коде, типа:

    Если ДопКонстантыПовтИсп.ЗначениеКонстанты(«ИмяКонстантыБулево») = Истина Тогда
    //Делать что то по-новому
    Иначе
    //Делать по-старому
    КонецЕсли;
    Reply
  53. myxins1989

    (52) Т.е. использование новой константы не прописывается в коде и не требует обновление? Создали новую константу «ПодставлятьЭтуОрганизациюВДокументРеализация», задали ей значение, и теперь во все реализации подставляется это значение? Или все-таки надо какой-то код прописать в конфигурации, который будет опираться на эту константу?

    Reply
  54. buganov

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

    Reply
  55. myxins1989

    (54) внешние модули — это внешние обработки?

    Reply
  56. lefthander

    Что бы не париться с альтами есть клавиатура от Чистова 😉

    Reply
  57. Бубузяка

    Для тех кто хочет «открыть для себя кофигуратор» советую почитать https://its.1c.ru/db/pub101advice

    Е. Ю. Хрусталева

    101 совет начинающим разработчикам в системе «1С:Предприятие 8»

    Электронная книга для публикации в информационной системе ИТС ПРОФ; ISBN 978-5-9677-2347-6.

    Версия издания от 07.04.2015.

    Электронный аналог издания «101 совет начинающим разработчикам в системе «1С:Предприятие 8»» (ISBN 978-5-9677-2322-3, М.: ООО «1С-Паблишинг», 2015; артикул печатной книги по прайс-листу фирмы «1С»: 4601546117618; по вопросам приобретения печатных изданий издательства «1С-Паблишинг» обращайтесь к партнеру «1С», обслуживающему вашу организацию, или к другим партнерам фирмы «1С»).

    В частности про подсвет кода тут https://its.1c.ru/db/pub101advice#content:10:hdoc

    Reply
  58. unlogic

    А как вам такое:

    В начале критически важных или отлаживаемых процедур пишем такое:

    &НаСервере
    Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)
    //************************************************
    ТекстПроцедуры = ОбщийМодульСерверныеПроцедуры.ПолучитьТекстПроцедуры(«имяДокумента.ФормаДокумента.ПриСозданииНаСервере»);
    Если не ТекстПроцедуры=»» Тогда
    Выполнить(ТекстПроцедуры);
    Возврат;
    //Для функций использовать конструкцию Возврат Вычислить(ТекстПроцедуры);
    КонецЕсли;
    //************************************************
    
    …. основной код ПриСоздании ….
    
    КонецПроцедуры
    

    Показать

    В общем модуле такая функция:

    Функция ПолучитьТекстПроцедуры(ИмяПроцедуры) Экспорт
    
    УстановитьПривилегированныйРежим(Истина);
    
    Запрос = Новый Запрос;
    Запрос.Текст =
    «ВЫБРАТЬ ПЕРВЫЕ 1
    | ТекстыМодулейЗапросов.Текст КАК Текст
    |ИЗ
    | Справочник.ТекстыМодулейЗапросов КАК ТекстыМодулейЗапросов
    |ГДЕ
    | НЕ ТекстыМодулейЗапросов.ПометкаУдаления
    | И ТекстыМодулейЗапросов.Наименование = &Наименование
    | И НЕ ТекстыМодулейЗапросов .ЭтоГруппа»;
    
    Запрос.УстановитьПараметр(«Наименование», ИмяПроцедуры);
    
    РезультатЗапроса = Запрос.Выполнить();
    
    ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать();
    
    Пока ВыборкаДетальныеЗаписи.Следующий() Цикл
    Возврат ВыборкаДетальныеЗаписи.Текст;
    КонецЦикла;
    УстановитьПривилегированныйРежим(Ложь);
    
    Возврат «»;
    
    
    КонецФункции
    
    

    Показать

    В справочнике ТекстыМодулейЗапросов в наименование кладем любую строку, по которой будем получать реквизит Текст.

    Написали кусок текста, скопировали весь текст процедуры в наш справочник, и не перезапуская 1С — выполним тело процедуры из справочника.

    Можно править прям в справочнике, но в управляемых формах это как в блокноте работать.

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

    Reply
  59. myxins1989

    (58) Видел такое, риб с более чем 50 узлами, только там патчи хранились в регистре сведений, одно из измерений было — узел риба.

    Reply
  60. unlogic

    (59) А как бы подгрузить весь текст из внешнего файла, например для модуля формы?

    В семерке такое было.

    Reply
  61. myxins1989

    (60) Я бы использовал этот вариант только для оперативных патчей — метод «Выполнить» выполняется дольше, чем обычный код. Текст процедуры можно просто прочитать из файла в строку и передать в метод Выполнить. Или там только на теории все гладко, а на практике есть ограничения?

    Reply
  62. unlogic

    (61) Да, конечно только для оперативных, и только на время разработки/доработки объектов конфигурации.

    Минус этого метода в том, что его нужно вставлять во все процедуры и функции.

    Хочется подгружать весь модуль из файла.

    Reply
  63. Sintson

    (12) Особенно это выручит в обработках запускаемых в различных базах. Пользователи будут приставать с вопросом «у меня в базе 1 работает а в базе 2 нет». А еще эта «Разработка» раздувает и запутывает текст программы. Никто его потом не рефакторит и конфигурация превращается в помойку.

    Reply
  64. Terve!R

    Предопределенные элементы — это, конечно, хорошо, только вы почему-то забываете, что все эти НайтиПоНаименованию появляются не от хорошей жизни, а когда что-то срочно надо поправить в коде, вставить для одного объекта исключение, и выгонять всех пользователей или ждать ночи просто невозможно. А когда это все спланировано и никто никуда не спешит, то конечно можно хоть на выходные добавление предопределенного элемента или целого регистра запланировать можно.

    Как насчет программного присвоения предопределенного имени ссылке прям на лету без завершения сеансов? Новая платформа вроде позволяет…

    Reply
  65. Terve!R

    (62) для оперативных правок есть расширения, которые потом можно отключать, и применяется все без обновления БД, ну только сеанс перезапустить, но это не проблема.

    Reply
  66. myxins1989

    (65) На самом деле там нечто похожее на динамическое обновление. Общался с одним из разработчиков платформы, говорят, что работает ощутимо стабильнее. Но не позволяет избежать монопольного доступа, если меняется структура данных (как, конечно, и в случае с патчами)

    Reply
  67. myxins1989

    (64) Хорошо, если не от хорошей жизни. Плохо, когда от незнания альтернатив. Добавление предопределенного объекта в справочник, в котором хранятся только эти предопределенные настройки, выполняется моментально, там же не будет тысяч/миллионов записей.

    Скорее всего имя предопределенного объекта должно быть на уровне конфигурации уже создано.

    Reply
  68. Dream_kz

    (63) ну во-первых надо думать как писать обработки запускаемые в разных базах. А если мы привязаны к наименованию/коду в одной базе, и боимся что их поменяют, то используем гуид, тут уж наверняка. А во-вторых, это просто инструмент, если вы его неправильно используете, это уже ваши проблемы.

    Reply
  69. Papilion

    Еще используем две константы «Режим разработки» и «Предрелизный код». Если переписываешь важный функционал, то «Если РежимРазработки Тогда новый код Иначе весь старый код КонецЕсли». Нажатием одной галочки, без выхода всех пользователей и правкой в конфигураторе ты возвращаешь весь рабочий функционал, до твоих нароботок. Когда проект закончен по поиску все подчищаешь. Тоже очень спасает. А режим разработки нужен чтобы можно было не держать модули, а помещать в рабочую базу, в рабочей базе он всегда выключен.

    Reply
  70. Serg O.

    Насчет «быстой» замены & и # через сочетания…. Конечно не плохо… Но лучше поставить punto switch если речь о постоянной смене раскладки… Тогда УЖЕ написанное не придётся стирать и заново писать…

    Reply
  71. Ndochp

    (70) Пунто конечно тоже мастхев (с отключенной автоматикой), но «клавиатура чистова» решает проблему недостатка знаков и запоминания Alt комбинаций гораздо удобнее.

    Единственный недостаток — если мотаешься по клиентам, то каждому это ставить неудобно.

    Reply
  72. kostas

    Очень давно используем именно РС «ГлобальныеЗначения». И функции в модуле с повторным использованием ПолучитьГлобальноеЗначение()

    Reply
  73. TreeDogNight

    (8) А ещё удобнее скачать раскладку клавиатуры от Павла Чистова и печатать все эти спец. знаки через зажатый правый альт 🙂

    Reply
  74. TreeDogNight

    (54) Тоже стало интересно, что имеете ввиду под внешними модулями?

    Reply
  75. TreeDogNight

    (56) Поддерживаю! Уже не представляю быстрой разработки без этой раскладки клавиатуры 🙂

    Reply
  76. buganov

    (74) использование методов модуля внешних обработок

    Reply
  77. myxins1989

    (76) Т.е. вы по незнанию (https://kb.1c.ru/articleView.jsp?id=111, https://its.1c.ru/db/metod8dev#content:5940:hdoc:_top:%D0%B2%D0%BB%D0%B8%D1%8F%D0%BD%D0%B8%D0%B5%20%D0%B2%D0%BD%D0­%B5%D1%88%D0%BD%D0%B8%D1%85%20%D0%BE%D0%B1%D1%80%D0%B0%D0%B1­%D0%BE%D1%82%D0%BE%D0%BA%20%D0%BF%D1%80%D0%BE%D0%B8%D0%B7%D0­%B2%D0%BE%D0%B4%D0%B8%D1%82%D0%B5%D0%BB%D1%8C%D0%BD%D0%BE%D1­%81%D1%82%D1%8C) или осознанно создаете механизмы, которые работают медленнее, чем встроенный в конфигурацию код, преследуя, судя по всему, одну цель — возможность быстро исправлять свои баги на лету, критикуете идею с запасной ролью с полными правами исключительно на вновь создаваемые объекты и рассказываете про то, как кодить без ошибок. Небось еще и версия платформы не выше 8.3.10.

    Reply
  78. acanta

    (77) модули, вынесенные во внешнюю компоненту под защитой СДК свободны от этих недостатков?

    Reply
  79. myxins1989

    (78) тут вся суть в том, что компиляция внешних обработок происходит налету, поэтому нагрузка на проц. Внешние компоненты уже скомпилированы, но там могут быть другие ожидания. Ну и все-таки модули СЛК выносят, чтобы защитить от несанкционированного использования, более эффективного способа я пока не встречал.

    Reply
  80. buganov

    (77) А Вы делали замеры? Ну, так уж, чтобы не быть голословным, и не прослыть обычным теоретиком, можно Ваши выкладки по времени?

    И при чем тут 8.3.10? Там какая то магия заложена? У нас 8.2 еще.

    Очень рад, что Вы начали изучать кб, но не забывайте, что не все, что пишут в учебниках-правда. И не все рекомендации актуальны.

    Reply
  81. buganov

    (79)

    нагрузка на проц

    Теория, оторванная от бизнеса.

    Я Вам снова разжую, так и быть. Представьте себе бизнес, работа которого заключается в доступности системы 24/7. Представьте, что в команде разработчиков есть люди, которые так же могут проглядеть баги. Так вот, что бы Выбрали Вы, супер директор, 100 мс ядра процессора или потерю сотни тысяч? Я думаю, что выбор очевиден. Тем более, что это всего лишь план Б. И в следующем цикле обновления фиксы переносятся в конфигурацию. Но в качестве поддержки затраты оправданы. Причем, начиная от горячей подмены формы объекта, заканчивая подгрузкой логики из модуля. Не думайте, что кругом одни дураки, и не опирайтесь на голую теорию.

    Reply
  82. buganov

    (65)и для старых версий платформы?

    Reply
  83. myxins1989

    (80) в более полной статье на кб как раз расписано, что в 8.3.10 обращение к внешним обработкам гораздо более медленное, чем 8.3.13. Если рядом с оголенным проводом написано, что он под напряжением, я не буду его трогать, даже под страхом прослыть теоретиком. Тем более в статье представлен конкретный результат замеров, а не теоретическая выкладка формул, которая доказывает, что будет медленнее.

    Reply
  84. myxins1989

    (80) и мне смысла делать замеры нет, я таким механизмом не пользуюсь. А вот вы похоже таких замеров не делали

    Reply
  85. buganov

    (83) План Б в виде патча из внешней обработки и выполнение кода на 7%(пустой метод) дольше ничтожные потери в сравнении с рисками, которые возникают в невозможности работы какого-то из механизмов. Вы ведь это понимаете, надеюсь?

    Reply
  86. myxins1989

    (85) теперь это уже патч, хотя вначале писалось, что стараетесь всю логику вытащить во внешние обработки. В статье кб более страшные цифры. А на 8.2 вообще замеров не делали, но судя по тенденции, будет только хуже.

    Reply
  87. buganov

    (84) замеры делал и результаты вполне удовлетворили.

    Я понимаю, что Вы такими механизмами не пользуетесь, просто примите за истину то, что есть компании, которые не могут в любой момент времени а) обновиться б) остановить процессы в) идти на такие риски.

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

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

    Reply
  88. myxins1989

    (87) в целом все понятно. Называете чужие планы Б костылями, свои план Б — механизмом. Остальное все как у всех —

    полных автоматизированных тестов нет, программисты не ошибаются только если ничего не делают. Знаете как надо жить правильно и всех этому учите, при этом сами живете как все.

    Reply
  89. buganov

    (86) доработки стараемся максимально вынести во внешние модули, либо на этапе проектирования нового объекта или механизма закладывается вариативность.

    Автоматика живет в общих модулях. Такими механизмами проще управлять, исправлять ошибки, дорабатывать.К тому же, вся инфраструктура уже заложена в БСП(Вы ведь знаете, что это такое?).

    В объекты добавлены бэкдоры в виде возможности использования методов внешних обработок на случай, если логика сломается в процессе доработки.

    судя по тенденции, будет только хуже

    Вы, судя по всему, любите тенденции, а не практику отказоустойчивого программирования.У меня в отделе вместо того, чтобы хлопать виновато глазками, выдавая полные права, есть возможность быстро нагорячую подключить патч.

    И еще раз повторюсь, надеюсь, что до Вас дойдет то, что бизнесу плевать на миллисекунды процессорного времени и далеко не плевать на сотни тысяч нефти потерь

    Reply
  90. l_men

    (40) Сегодня еще добавил в шаблоны код внешних обработок для типовых конфигураций 1С. Замучился каждый раз вспоминать какие там параметры надо указывать.

    #Область Сведения_о_внешней_обработке
    Функция СведенияОВнешнейОбработке() Экспорт
    ПараметрыРегистрации = Новый Структура;
    ПараметрыРегистрации.Вставить(«Вид», «ПечатнаяФорма»); //может быть — ПечатнаяФорма, ЗаполнениеОбъекта, ДополнительныйОтчет, СозданиеСвязанныхОбъектов…
    ПараметрыРегистрации.Вставить(«Наименование»,  «Приказ на премии (т-11)»);
    ПараметрыРегистрации.Вставить(«Версия», «1.0»);
    ПараметрыРегистрации.Вставить(«БезопасныйРежим», Истина);
    ПараметрыРегистрации.Вставить(«Информация», «Собственный приказ на премии»);
    
    ТаблицаКоманд = ПолучитьТаблицуКоманд();
    ДобавитьКоманду(ТаблицаКоманд,
    «Приказ на премии (одиночный)»,
    «1»,
    «ВызовСерверногоМетода»,
    Истина,»»
    
    );
    ПараметрыРегистрации.Вставить(«Команды», ТаблицаКоманд);
    Возврат ПараметрыРегистрации;
    КонецФункции
    
    Функция ПолучитьТаблицуКоманд()
    Команды = Новый ТаблицаЗначений;
    Команды.Колонки.Добавить(«Представление», Новый ОписаниеТипов(«Строка»));
    Команды.Колонки.Добавить(«Идентификатор», Новый ОписаниеТипов(«Строка»));
    Команды.Колонки.Добавить(«Использование», Новый ОписаниеТипов(«Строка»));
    Команды.Колонки.Добавить(«ПоказыватьОповещение», Новый ОписаниеТипов(«Булево»));
    Команды.Колонки.Добавить(«Модификатор», Новый ОписаниеТипов(«Строка»));
    Возврат Команды;
    КонецФункции
    
    Процедура ДобавитьКоманду(ТаблицаКоманд, Представление, Идентификатор, Использование, ПоказыватьОповещение = Ложь, Модификатор = «»)
    НоваяКоманда = ТаблицаКоманд.Добавить();
    НоваяКоманда.Представление = Представление;
    НоваяКоманда.Идентификатор = Идентификатор;
    НоваяКоманда.Использование = Использование;
    НоваяКоманда.ПоказыватьОповещение = ПоказыватьОповещение;
    НоваяКоманда.Модификатор = Модификатор;
    КонецПроцедуры
    #КонецОбласти

    Показать

    Reply
  91. buganov

    (88)

    Знаете как надо жить правильно и всех этому учите, при этом сами живете как все.

    Вообще в дебри ушел…

    Я думаю, что на этом стоит закончить диалог. Вы все-равно, видимо, не поймете мысль, которую я пытался до Вас донести, в итоге обиделись и пытаетесь меня забросать буквами.

    Кстати, механизм подключаемых модулей придуман не мной. Я подсмотрел его в нескольких особокрупных компаниях, одна из которых Контур с EDI. У них так же специфика бизнеса такая, что лучше уж затратить время процессора и на костылях дойти до релиза, чем получить нерабочую систему и потерять деньги. Я понимаю, что ООО Ромашка очень трепетно может относиться к своей технике, да так, что процессорное время дороже, чем время бизнеса, в компаниях чуть крупнее появляется необходимость в горячем переключении.

    Удачи Вам, воспринимайте критику, как возможность вырасти.

    Reply
  92. myxins1989

    (89) Про полные права речи не было

    Reply
  93. buganov

    (77) не поленился, даже пересмотрел этот момент курса Богачева.

    Так вот, этот замер из статьи делал множество вызовов методов обработок(встроенных, в расширении, внешних). В таком режиме я соглашусь, что использование внешних обработок очень даже вредно, тк компиляция будет при каждом новом обращении.

    У меня же в базах вариант передачи управления в модуль внешней обработки, полностью перенося функционал туда. Компиляция производится один раз и за миллисекунды. Единственный минус — невозможность отладки на продуктах, если что-то пойдет не так.

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

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *