Для решения задачи мы будем использовать функцию ВыгрузитьПоПравилу(), которой будем передавать всего два параметра: Источник и имя ПКО. Создадим ПКО РасчетныеСчета, настроим соответствие реквизитов Источника и Приемника. Именно этому ПКО мы через функцию ВыгрузитьПоПравилу() будем передавать данные по подчиненным справочникам РасчетныеСчета от Источинка к Приемнику.
Благодаря тому, что почти все реквизиты Источника и Приемника совпадают по названию и смыслу, мы просто создаем новое ПКО и проставляем соответствие реквизитов, отмечаем флажки Поиск у соответствующих полей:
Следующим этапом стоит задача отладить ПКО Контрагенты. Что мы будем делать:
СпрРасчетныеСчета = СоздатьОбъект("Справочник.РасчетныеСчета"); СпрРасчетныеСчета.ИспользоватьВладельца(Источник.ТекущийЭлемент()); СпрРасчетныеСчета.ВыбратьЭлементы(); Пока СпрРасчетныеСчета.ПолучитьЭлемент() = 1 Цикл ВыгрузитьПоПравилу(СпрРасчетныеСчета.ТекущийЭлемент(), , , , "РасчетныеСчета", , , ); КонецЦикла;
Обращаем внимание, что мы передаем два параметра функции ВыгрузитьПоПравилу: Источник - очередной расчетный счет при выборке и ИмяПКО - имя ранее созданного ПКО РасчетныеСчета. Процедура После выгрузки описана в справочнике.
Следующий этап состоит в том, чтобы загрузить в реквизит ОсновнойСчет один из загруженных ранее расчетных счетов. Делается это опять же в ПКО Контрагенты, но только теперь уже в процедуре После загрузки:
СпрРасчетныеСчета = СоздатьОбъект("Справочник.РасчетныеСчета"); СпрРасчетныеСчета.ИспользоватьВладельца(Объект.ТекущийЭлемент()); СпрРасчетныеСчета.ВыбратьЭлементы(); Пока СпрРасчетныеСчета.ПолучитьЭлемент() = 1 Цикл // поскольку в источнике нет понятия основной счет, возьмем первый попавшийся и "впихем" его // в реквизит ОсновнойСчет Объект.ОсновнойСчет = СпрРасчетныеСчета.ТекущийЭлемент(); Прервать; КонецЦикла;
Итак, что сделано на данном этапе:
Претензии и возражения по статье принимаются, т.к. автор осваивает громадные возможности КД и описал задачу, как он решал сам. Решение полностью работоспособное.