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

23.10.17

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

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

Файлы

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

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

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

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

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

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

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

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

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

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

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


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

 

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

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

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

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

 

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

 

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

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

 

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

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

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

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

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

 

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

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

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

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

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


 

 

Вступайте в нашу телеграмм-группу Инфостарт

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

См. также

SALE! 10%

Перенос данных 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 24894 руб.

12.06.2017    148593    867    302    

455

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    174087    378    288    

404

Перенос данных 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    191568    626    537    

546

Перенос данных 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    59020    284    75    

224

SALE! 10%

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

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена | Можно выполнить переход с УПП на БП 3 или запускать выгрузку данных за выбранный период времени | Переносятся документы, начальные остатки и вся справочная информация | Есть фильтр по организации и множество других параметров выгрузки | Поддерживается несколько сценариев работы: как первичный полный перенос, так и перенос только новых документов | Перенос данных возможен в "1С: Бухгалтерия 3.0" версии ПРОФ, КОРП или базовую | Переход с "1С: УПП1.3" / "1С:КА 1.1" на "1С:БП3.0" с помощью правил конвертации будет максимально комфортным! | Можно бесплатно проверить перенос на вашем сервере!

48278 43450 руб.

25.02.2015    175232    319    267    

388

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

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

35000 руб.

15.12.2021    27907    198    58    

153

SALE! 10%

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

Перенос данных из КА 1.1 в КА 2 | из КА 1.1 в УТ 11 | Воспользовались более 367 компаний! | Переносятся все возможные виды документов, начальных остатков и вся справочная информация из "1С:КА 1.1" в "1С:КА 2.х" / "1С:УТ 11" | Разработан в формате КД 2 (правила конвертации данных) | Фильтр по организациям при выгрузке | Выбор разных алгоритмов выгрузки начальных остатков | Можно проверить перенос до покупки!

55778 50200 руб.

04.12.2015    194382    254    351    

409

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    39772    112    73    

106
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
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
Оставьте свое сообщение