gifts2017

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

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

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

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

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

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

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

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

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

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



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

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

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

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

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

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

См. также

PowerTools от 1 000
Подписаться Добавить вознаграждение

Комментарии

1. Герман (German) 26.11.08 09:59
Было уже во многих обработках:
Например в Ei:
Кроме встроенного языка+установка реквизитов+проведение+загрузка данных. Причем для любых данных не только находящихся в БД...
2. kitt al;dskjf;ldasjkf (kitt) 26.11.08 10:06
German так я на эксклюзивный патент и не претендую.
3. kitt al;dskjf;ldasjkf (kitt) 26.11.08 10:09
Кроме того Ei - 2.5 Mb, ГрупповаяОбработкаСправочниковИДокументов - 45 Kb.
5. kitt al;dskjf;ldasjkf (kitt) 26.11.08 10:41
Меня длинным гуглевским урлом не напугаешь ))
6. Алексей Коробов (WiseSnake) 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) 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) 29.06.15 09:41
Приветствую всех! Кому надо разработать код для данной обработки, пишите на isihome@yandex.ru (предоплата)
22. Осипов Сергей (fixin) 09.10.15 13:27
да. действительно маст-хэв. Можно отобрать сразу несколько документов и сделать с ними что захочешь, например я использовал для удаления объектов. ;-)
23. Константин Исиченко (IsiKosta) 23.11.16 07:52
На управляемых формах ? В описании надо бы указать, это важно.
24. Константин Исиченко (IsiKosta) 23.11.16 07:53
Картинку очень желательно добавлять в описание!
25. kitt al;dskjf;ldasjkf (kitt) 23.11.16 13:42
(23) IsiKosta, смотри дату публикации и включай голову
Для написания сообщения необходимо авторизоваться
Прикрепить файл
Дополнительные параметры ответа