В помощь программисту: "Групповая обработка справочников и документов" с выполнением произвольного кода.

Опубликовал kitt al;dskjf;ldasjkf (kitt) в раздел Программирование - Инструментарий

Расширение возможностей типовой обработки "Групповая обработка справочников и документов".

Мне часто приходиться пользоваться типовой обработкой "Групповая обработка справочников и документов". Она довольна удобна: можно обработать любые справочники и документы, имеющиеся в конфигурации, встроенный гибкий отбор, возможность изменять реквизиты и табличные части. Вот только иногда бывают ситуации, когда новое значение реквизита нельзя задать в виде константы для всех обрабатываемых элементов, а нужно формировать его из каких-нибудь данных текущего обрабатываемого элемента. Или с отобранными элементами нужно провести более широкий ряд действий, чем просто пометка на удаление, проведение, отмена проведения и т.д. То есть, выполнить какой-то произвольный код, вписанный в обработку в режиме "Предприятия".

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

В самой форме обработки нововедений всего два: в списке действий появилось действие "Выполнить код[...]", и появилась новая закладка с полем для кода, который будет исполняться.

Открываем обработку, выбираем справочник "Номенклатура", в поле "Отбор" добавляем новую строку: Поле = ПолноеНаименование; ТипСравнения=Равно; Значение=""; (то есть пустая строка) и нажимаем кнопку "Отобрать". Переходим на закладку "Обработка" там должна появиться таблица с элементами справочника, удовлетворяющих указанному условию отбора (то есть с незаполненным ПолнымНаименованием).

Теперь собственно основной момент. Переходим на закладку "Код обработки" и вводим там код, который будет выполняться над каждым отмеченным элементом справочника номенклатура отобранным в прошлом шаге. Код будет примерно такой:

//Значение ссылки на элемент справочника или документа
//обрабатываемой в текущей итерации отобранных и отмеченных элементов
//доступно через переменную "ТекСсылка"
СпрОбъект = ТекСсылка.ПолучитьОбъект();
СпрОбъект.ПолноеНаименование = СокрЛП(ТекСсылка.Наименование)+" "+СокрЛП(ТекСсылка.Артикул);

Попытка
   СпрОбъект.Записать();
   Сообщить(""+ТекСсылка+" элемент записан.");
Исключение
   Сообщить("Не удалось записать элемент: "+ТекСсылка+" "+ОписаниеОшибки());
КонецПопытки;



То есть обработка будет в цикле перебирать все отмеченные строки таблицы с отобранными объектами, и в каждой итерации вызывать оператор "Выполнить()" с нашим кодом.

Возвращаемся на закладку "Обработка" , в списке действий выбираем "Выполнить код[...]" и нажимаем кнопку "Выполнить".

Вот в принципе и все.

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

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

Наименование Файл Версия Размер
ГрупповаяОбработкаСправочниковИДокументов
.1227666914 45,15Kb
19.10.14
645
.1227666914 45,15Kb 645 Скачать

См. также

Комментарии
1. Герман (German) 930 26.11.08 09:59 Сейчас в теме
Было уже во многих обработках:
Например в Ei:
Кроме встроенного языка+установка реквизитов+проведение+загрузка данных. Причем для любых данных не только находящихся в БД...
2. kitt al;dskjf;ldasjkf (kitt) 319 26.11.08 10:06 Сейчас в теме
German так я на эксклюзивный патент и не претендую.
3. kitt al;dskjf;ldasjkf (kitt) 319 26.11.08 10:09 Сейчас в теме
Кроме того Ei - 2.5 Mb, ГрупповаяОбработкаСправочниковИДокументов - 45 Kb.
5. kitt al;dskjf;ldasjkf (kitt) 319 26.11.08 10:41 Сейчас в теме
Меня длинным гуглевским урлом не напугаешь ))
6. Алексей Коробов (WiseSnake) 1723 26.11.08 13:58 Сейчас в теме
У меня тоже есть такая же разработка(сам писал) ))) но со временем я от нее отказался...
Попробуйте попользоваться http://www.infostart.ru/profile/15778/projects/2795/, но со временем Вам понравится(я уже пользуюсь только ей), тем более я скоро продолжу описание http://www.infostart.ru/profile/15778/blogs/709/ (извините за рекламу я не со зла)
7. Лилия (lakzn) 29.10.09 16:06 Сейчас в теме
kitt, спасибо! Быстро, просто и как раз то, что нужно ))
8. Евгений Доронин (scoboy) 02.12.09 20:00 Сейчас в теме
9. Леха (Shin0o) 22.06.10 11:24 Сейчас в теме
Спасибо хорошая обработка а самое главное очень гибкая.
Респект kitt :idea:
10. Lizi60 (Lizi60) 08.10.10 10:38 Сейчас в теме
11. Александр Крутой (Alex@ander) 20.09.11 03:51 Сейчас в теме
Спасибо огромное, в своё время обработка очень мне помогла!
12. arjuna (arjuna) 20.09.11 23:09 Сейчас в теме
Спасибо, мне помогла. Есть пожелание: для примера показать в закомментированом виде наиболее распространенные варианты кода.
13. Аннамара Пергамент (pannamara) 01.10.11 16:07 Сейчас в теме
Спасибо, постоянно использую, очень удобно
14. Lizi60 (Lizi60) 18.11.11 15:12 Сейчас в теме
Очень полезная обработка. Пользуюсь постоянно. Спасибо автору.
15. Юрий Милохов (Murik_1984) 1 18.11.11 15:27 Сейчас в теме
Я считаю, чем обработка универсальнее, тем она так сказать неудобнее. Я заметил, что в универсальных обработках есть бока, которые проявляются в нетиповых решениях. Поэтому конечно люди пишут свои. Мне например эта подошла как раз, и интерфейс я сделал бы таким же, если бы писал сам. Спасибо автору и удачи.
16. samir omarov (balabani) 23.11.11 02:11 Сейчас в теме
Спасибо хорошая обработка
17. mike mike (hedgehog.net) 21.12.11 18:06 Сейчас в теме
Я не понял, а как обратится к объекту если нужно обработать и табличные части и реквизиты документов ?
19. cratos2 (CratosX) 20.02.12 15:27 Сейчас в теме
(17) hedgehog.net,
Документ.ПоступлениеТоваров.Товары.__НужныйРеквизит__
20. михаил забудько (mihaizum) 17.07.13 22:17 Сейчас в теме
Обработка классная! спасибо!
21. Константин Исиченко (IsiKosta) 697 29.06.15 09:41 Сейчас в теме
Приветствую всех! Кому надо разработать код для данной обработки, пишите на isihome@yandex.ru (предоплата)
22. Осипов Сергей (fixin) 3517 09.10.15 13:27 Сейчас в теме
да. действительно маст-хэв. Можно отобрать сразу несколько документов и сделать с ними что захочешь, например я использовал для удаления объектов. ;-)
23. Константин Исиченко (IsiKosta) 697 23.11.16 07:52 Сейчас в теме
На управляемых формах ? В описании надо бы указать, это важно.
24. Константин Исиченко (IsiKosta) 697 23.11.16 07:53 Сейчас в теме
Картинку очень желательно добавлять в описание!
25. kitt al;dskjf;ldasjkf (kitt) 319 23.11.16 13:42 Сейчас в теме
(23) IsiKosta, смотри дату публикации и включай голову
Оставьте свое сообщение