Быстрое создание правил регистрации и написания кода в обработчиках

23.10.17

Интеграция - Перенос данных 1C

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

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Создание и групповая обработка правил регистрации
.epf 13,73Kb ver:1.0
48
48 Скачать (1 SM) Купить за 1 850 руб.

 Обработка похожа на эту: //infostart.ru/public/194617/ (собственно публикую что-то впервые, поэтому, возможно, будет чем-то похоже описание). Но так как у меня задача была более специфична, решил написать свою - более функциональную. В конце опишу с чем столкнулся я, и как решил. Думаю, что кому-нибудь окажется полезной эта информация.

Возможности:

1. Быстрое создание правил регистрации для всех объектов метаданных.

2. Создание одной кнопкой одностороннего обмена.

3. Очистка кода во всех обработчиках событий.

4. Возможность быстрого написания своего кода в выбранный обработчик.

5. Выбор типа объекта для написания кода(все справочники, все документы и т.д.).

6. Написание кода только в выбранные объекты табличной части.


Теперь подробнее о создании правил(если с выгрузкой и загрузкой метаданных, а также созданием правил знакомы, переходите к пункту 4.):

 

1. Выгружаем структуру метаданных из нужной конфигурации. Для этого открываем программе в режиме предприятия стандартную обработку "Выгрузка описания структуры метаданных". Находится в папке, куда была установлена конфигурация "Конвертация данных". В каталоге называется "MD83Exp" или "MD82Exp" для версии 8.Х. Ставим галочки напротив пунктов: "Выгружать регистры сведений", "Выгружать регистры накопления", "Выгружать регистры бухгалтерии" и "Выгружать регистры расчета". Жмем выгрузить.

2. Открываем программу конвертация данных. Жмем пункт "Загрузить структуру метаданных конфигурации". Оставляем галочки, как на изображении. Жмем "выполнить загрузку".

3. Создаем новую регистрацию по нужному плану обмена.

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

 

5. Переходим на следующую вкладку. Для добавления кода в определенный тип объектов выбираем нужный и жмем рядом кнопку. Ну а если требуется добавить в конкретные объекты - добавляем их в табличную часть и нажимаем Прописать текст в обработчиках выбранных объектов в табличной части

 

 Аналогично для очистки обработчиков нужных объектов оставляем Текст обработчика пустым.

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

 

Подробнее о задаче.

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

Процедура СократитьПолучателей(Объект, Узлы)

Описание:
Вычитает из списка узлов-получателей объекта переданные значения узлов.

Параметры:
Объект (обязательный) – объект, для которого выполняется правило регистрации
Узлы (обязательный) – Массив – узлы плана обмена, которые необходимо вычесть из списка узлов-получателей объекта

 

Делал все, как описано, но ничего не сработало. Далее посмотрел отладчиком и увидел, что значения узлов для регистрации содержатся в определенном массиве. А в выше описанной процедуре работа идет с данными из другого массива, и на тот, в котором содержатся данные узлов, не влияет. Более того в процедуре он пуст. В него можно добавить значения с помощью еще одной процедуры "Процедура ДополнитьПолучателей(Объект, Узлы)". Но опять же это ни на что не влияет. То есть, как регистрировалось для всех так и продолжает. Дошло до того, что начал уже допиливать конфигурацию, но все-таки придумал, как ограничиться изменением только правил регистрации. Например, в узлы кроме корневого нужно перенести только документ поступление. Для этого в обработчике "После обработки" всех документов, кроме поступления пишем следующий код.

Получатели.Очистить();
Получатели.Добавить(ПланыОбмена.Полный.НайтиПоНаименованию("Корень"));

 Далее, чтобы данные регистров регистрировались только для документа поступление пишем в обработчике "После обработки" регистров.

Если НЕ ТипЗнч(Объект.Отбор.Регистратор.Значение) = ТипЗнч(Документы.ПоступлениеТоваровУслуг.ПустаяСсылка()) Тогда
    Получатели.Очистить();
    Получатели.Добавить(ПланыОбмена.Полный.НайтиПоНаименованию("Корень"));
КонецЕсли;

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


 

 

правила регистрации групповая обработка

См. также

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 Оперативный учет 1С:Управление торговлей 10 Россия Управленческий учет Платные (руб)

Перенос данных из 1С:Управление торговлей 10.3 в 1С:Управление торговлей 11.5 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УТ 10.3 (10.3.88.x) и УТ 11.5 (11.5.21.x).

35000 руб.

23.07.2020    57050    266    75    

221

SALE! 15%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Россия Платные (руб)

Правила в универсальном формате обмена для ERP 2.5, КА 2.5, УТ 11.5, БП 3.0, Розница, УНФ, для последних версий конфигураций. Ссылки на другие конфигурации в описании публикации. Правила совместимы со всеми другими версиями конфигураций новыми и старыми, поддерживающими обмен и синхронизацию в формате EnterpriseData. Не требуется синхронного обновления правил после обновления другой конфигурации, участвующей в обмене. Типовой обмен через планы обмена кнопкой Синхронизация вручную или автоматически по расписанию, или вручную обработкой.

27660 руб.

12.06.2017    146472    861    300    

443

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Платные (руб)

Перенос данных из ERP в БП 3 | из КА 2 в БП 3 | из УТ 11 в БП 3 | из ЕРП в БП 3 | Сэкономьте время - используйте готовое решение для перехода! | Перенос разработан в формате КД 2 (правила конвертации данных) | Переносятся все возможные виды документов, начальных остатков и нормативно-справочная информация| Можно опционально выгружать каждую пару "номенклатура+характеристика" как отдельную номенклатуру | Есть выгрузка настроек счетов учета и зарплатных данных из ERP / КА 2 | Можно проверить на вашем сервере перед покупкой

55778 50200 руб.

15.04.2019    74791    202    156    

140

SALE! 10%

Перенос данных 1C Программист Платформа 1С v8.3 1С:Управление производственным предприятием 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Платные (руб)

Перенос документов, начальных остатков и справочной информации из УПП 1.3 в ERP 2 | из УПП 1.3 в УТ 11 | из УПП в КА 2 | Правила конвертации (КД 2) | Более 360 предприятий выполнили переход с использованием этого продукта! | Сэкономьте время - используйте готовое решение для перехода! | Позволяет перенести из УПП 1.3 в ERP / УТ 11 / КА 2 всю возможную информацию | В переносе есть фильтр по организации и множество других опциональных параметров выгрузки | Есть несколько алгоритмов выгрузки остатков на выбор

55778 50200 руб.

04.08.2015    171609    365    283    

394

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Управление производственным предприятием 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УПП 1.3 (1.3.244.x) и БП 3.0 (3.0.172.x). Правила подходят для версии ПРОФ и КОРП.

35000 руб.

15.12.2021    26716    191    56    

145

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из ERP в ЗУП 3 | из КА 2 в ЗУП | Готовые правила конвертации данных (КД 2) для переноса остатков, документов с движениями и справочной информации 3 | Есть перенос начальной задолженности по зарплате и начальной штатной расстановки на выбранную дату | Обороты за прошлые годы (данные для расчета среднего) переносятся свернуто в документ "Перенос данных" | Есть фильтр по организациям | Документы за текущий период переносятся сразу с движениями, поэтому не потребуется делать перерасчеты | Перенос можно проверить перед покупкой, обращайтесь!

53111 47800 руб.

03.12.2020    38748    109    70    

103

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 Платформа 1C v8.2 1С:Комплексная автоматизация 1.х 1С:Управление торговлей 10 1С:Управление производственным предприятием Россия Платные (руб)

Регулярный обмен, выгрузка, перенос из КА 1.1, УПП 1.3, УТ 10.3 для обмена с любыми конфигурациями, поддерживающими обмен в формате EnterpriseData (КД3) - БП 3.0, ERP, КА 2, УТ 11, Розница 2, УНФ 1.6 и другими. Правила для старых и доработанных конфигураций не требуют синхронного обновления и совместимы с новыми и будущими конфигурациями. Обмен по расписанию, через папку, FTP, почту.

16260 руб.

18.02.2016    189704    618    534    

537

Перенос данных 1C Программист Бухгалтер Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет НДФЛ ФОМС, ЕФС Платные (руб)

Обработки для быстрого перехода с конфигураций «КАМИН:Расчет заработной платы 3.0», «КАМИН:Зарплата для бизнеса 4.0» и «КАМИН:Зарплата 5.0» на конфигурацию «Зарплата и управление персоналом» версии 3.1.

12000 руб.

25.09.2016    83176    346    254    

295
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. jobkostya1c_ERP 101 07.09.15 20:06 Сейчас в теме
Запомню, стоит посмотреть (только не на ночь)
2. w.r. 653 08.09.15 12:48 Сейчас в теме
Допиленный вами код написан коряво:
- При нахождении нужного условия цикл не прерывается
- Зачем-то сравнивается тип значение с типом значения пустой ссылки, хотя по логике должно написано быть вот так:
Если Узел.Наименование = "ПодчиненныйУзел" И ТипЗнч(Объект.Ссылка) = Тип("ДокументСсылка.ПоступлениеТоваровУслуг") Тогда

- Зачем-то создается массив, добавляется элемент туда и все-равно потом берется первый элемент!
- Вот эта страшная конструкция:
Получатели[Получатели.Найти(ПланыОбмена.Полный.НайтиПоНаименованию("Корень"))]

Вообще непонятна!

Автор страшно после такого кода пользоваться вашими рекомендациями
3. Oleg-and-reevich 6 08.09.15 14:40 Сейчас в теме
(2) w.r., Да Вы правы. Наверное, на тот момент, когда была найдена эта идея, мозг уже плохо соображал. Понял, что по сути здесь ни цикл, ни сравнение не нужно(касательно документов). Можно ограничиться всего двумя строчками кода, только в этом конкретном случае не писать код в обработчике документа Поступление.

 Получатели.Очистить();
    Получатели.Добавить(ПланыОбмена.Полный.НайтиПоНаименованию("Корень"));


А в регистрах оставить одно сравнение по типу значения регистратора.
Большое спасибо, что указали на этот существенный недостаток. Сейчас сам смотрю и не понимаю, как такую ахинею написал. Текст отредактирую.
Designer1C; +1 Ответить
4. vdmkvrshn 14 23.01.17 10:40 Сейчас в теме
Пара замечаний:
1) В обработчиках кнопок, вызывающих сложнообратимое изменение в данных, правилами хорошего тона является показ вопроса о подтверждении выполняемого действия;
2) Зачем создавать правила регистрации для ВСЕХ объектов метаданных? Имеет смысл создавать их только для тех объектов, которые входят в план обмена, т.е. только для того списка, который дает типовая конвертация в выборе объекта метаданных при ручном создании правил.

Я то это дописал за пару минут, но вот так нажал на кнопку - потом пришлось помечать на удаление всю эту кучу правил для объектов из УТ11 и удалять помеченные.
5. пользователь 23.10.17 14:55
Сообщение было скрыто модератором.
...
6. Oleg-and-reevich 6 11.12.17 15:30 Сейчас в теме
Друзья. Прошу прощения за косяки, но сейчас нет времени на исправление. По всем вопросам напишите мне на почту olegas-olegich@yandex.ru
Оставьте свое сообщение