Перенос Номенклатура + Характеристика в один элемент Номенклатура

06.07.15

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

Выгрузка Номенклатура + Характеристика в одну Номенклатуру на примере обмена УТ 10.3-БП 2.0.
Удобство данного решения в том, что можно переносить и элементы справочника Номенклатура, и Номенклатура + Характеристика.

Скачать файл

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

Наименование По подписке [?] Купить один файл
Правила обмена данными
.xml 1,69Mb ver:1
24
24 Скачать (1 SM) Купить за 1 850 руб.

Изначально метод был описан тут: http://forum.infostart.ru/forum26/topic77014/message916608/?result=edit#message916608. Так как возникло много сопутствующих вопросов и просьба выложить готовый файл с правилами, то решил оформить это в отдельную статью.

Выгрузку необходимо производить через обработку "Универсальный обмен данными в формате XML" версии не ниже 2.1.7.
В результате работы данных правил создается документ ВводНачальныхОстатков с заполненной табличной частью МПЗПриобретенные.
Описываемый алгоритм реализован в выгрузке только этого типа документов.
Исходные данные берутся из регистра ПартииТоваровНаСкладах.
Перед выгрузкой необходимо заполнить параметр ДатаОстатков, для получения остатков на эту дату.
Основные моменты описаны последовательно по пунктам.
У кого что не получается, пишем в комментариях.
Если кому-то эта статья не интересна, то можно ничего не писать в комментариях, так будет даже лучше.

1. В конфигурации базы-приемника (Бухгалтерия) в справочнике Номенклатура добавить два новых реквизита для элементов и групп. В этих реквизитах будут храниться УИДы справочников из базы УТ. По сочетанию УИДНоменклатура + УИДХарактеристика будет производиться поиск элемента при загрузке.

    УИДНоменклатура, тип строка, длина 36
    УИДХарактеристика, тип строка, длина 36.
        
2. Заполнение значения реквизита УИДНоменклатура для поиска и/или заполнения в базе-приемнике. В ПКО Номенклатура добавить новый ПКС. Источник пустой, получатель УИДНоменклатура. В событии ПередВыгрузкой пишем код:  

Если ТипЗнч(Источник) = Тип("СправочникСсылка.Номенклатура") Тогда
    Значение = Строка(Источник.УникальныйИдентификатор());
Иначе
    Значение = Строка(Источник.Ссылка.УникальныйИдентификатор());
КонецЕсли;


3. Заполнение значения реквизита УИДХарактеристика для поиска и/или заполнения в базе-приемнике. В ПКО Номенклатура нужно добавить новый ПКС. Источник пустой, получатель УИДХарактеристика. Значение реквизита берется из входящих данных через попытку, чтобы ислючить появление сообщения об ошибке, при отсутствии этих данных. В событии ПередВыгрузкой пишем код:

Если Источник.ЭтоГруппа Тогда
	Значение = "";
Иначе
	
	Попытка
		
		Если ТипЗнч(ВходящиеДанные.ХарактеристикаНоменклатуры) = Тип("СправочникСсылка.ХарактеристикиНоменклатуры") Тогда
			Значение = Строка(ВходящиеДанные.ХарактеристикаНоменклатуры.УникальныйИдентификатор());
		Иначе
			Значение = Строка(ВходящиеДанные.ХарактеристикаНоменклатуры.Ссылка.УникальныйИдентификатор());
		КонецЕсли;
		
	Исключение
		Значение = "";
	КонецПопытки;
	
КонецЕсли;


4. В ПКО Номенклатура:
    Установить галочку поиск только у реквизитов: УИДНоменклатура, УИДХарактеристика, Родитель, ЭтоГруппа, Наименование.
    Установить галочку "Не запоминать выгруженные объекты".
    Установить галочку "Автоматически генерировать номер или код, если он не задан".
    Поиск по уникальному идентификатору необходимо снять.
    В событии Поля поиска поместить код:

Если СвойстваПоиска.Получить("ЭтоГруппа") Тогда
	СтрокаИменСвойствПоиска = "Наименование, ЭтоГруппа, Родитель";
Иначе	
	СтрокаИменСвойствПоиска = "УИДНоменклатура, УИДХарактеристика, ЭтоГруппа, Родитель";
КонецЕсли;

   
5. В ПКС Наименование ПКО Номенклатура событие ПередВыгрузкой:

Значение = Источник.Наименование;

Если Не Источник.ЭтоГруппа Тогда
	Попытка
		Значение = Значение + " " + ВходящиеДанные.ХарактеристикаНоменклатуры.Наименование;
	Исключение
	КонецПопытки;
КонецЕсли;

   
6. В ПКС Наименование Полное ПКО Номенклатура событие ПередВыгрузкой:

Значение = Источник.Наименование;

Если Не Источник.ЭтоГруппа Тогда
	Попытка
		Значение = Значение + " " + ВходящиеДанные.ХарактеристикаНоменклатуры.Наименование;
	Исключение
	КонецПопытки;
КонецЕсли;


7. В ПКС Номенклатура, связанным с реквизитом выгружаемого документа, в событии ПередВыгрузкой располагается код, который при заполненной характеристике производит выгрузку с передачей значения характеристики. В данном случае это ПКС Номенклатура ПКГС МПЗПриобретенные документа ВводНачальныхОстатков.

ИсходящиеДанные = Новый Структура;

Если ЗначениеЗаполнено(ОбъектКоллекции.ХарактеристикаНоменклатуры) Тогда
	ИсходящиеДанные.Вставить("ХарактеристикаНоменклатуры", ОбъектКоллекции.ХарактеристикаНоменклатуры);
Иначе
	ИсходящиеДанные.Вставить("ХарактеристикаНоменклатуры", Справочники.ХарактеристикиНоменклатуры.ПустаяСсылка());
КонецЕсли;

ВыгрузитьПоПравилу(ОбъектКоллекции.Номенклатура,, ИсходящиеДанные,,"Номенклатура");

 8. Результат в виде документов Ввода начальных остатков с разбивкой по организациям и счетам учета.

Конвертация Номенклатура Характеристика Выгрузка

См. также

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 руб.

12.06.2017    145749    849    299    

439

Перенос данных 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    56217    257    73    

212

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    170741    360    282    

391

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    74289    199    155    

137

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    38361    108    70    

102

Перенос данных 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    26138    187    56    

143

Перенос данных 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    189195    616    534    

537

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

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

35000 руб.

24.06.2020    64927    81    28    

94
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. dexxxqqq 05.01.16 21:00 Сейчас в теме
Спасибо за Ваш труд! Подошло и для УТ 11.1 -> БП 3.
Может быть кому пригодится, в 7-м пункте вместо ОбъектКоллекции.ХарактеристикаНоменклатуры просто ОбъектКоллекции.Характеристика. Вот так:

ИсходящиеДанные = Новый Структура;

Если ЗначениеЗаполнено(ОбъектКоллекции.Характеристика) Тогда
    ИсходящиеДанные.Вставить("ХарактеристикаНоменклатуры", ОбъектКоллекции.Характеристика);
Иначе
    ИсходящиеДанные.Вставить("ХарактеристикаНоменклатуры", Справочники.ХарактеристикиНоменклатуры.ПустаяСсылка());
КонецЕсли;

ВыгрузитьПоПравилу(ОбъектКоллекции.Номенклатура,, ИсходящиеДанные,,"Номенклатура");
Показать
2. avbolshakov 18.04.16 12:49 Сейчас в теме
Спасибо. Получилось все для ут11 -->> бп 3,0 . А вы не можете подсказать как всю номенклатуру запихнуть в приемнике в определенную папку. Понятно, что проверяем Родителя, если он на верху дерева, то назначить ему родителя нашу новую папку. Но вот где это лучше указать
3. anchovy 24 20.04.16 12:41 Сейчас в теме
(2) avbolshakov, Событие "После загрузки" в ПКО Номенклатура попробуйте использовать.
avbolshakov; +1 Ответить
4. user793598 06.09.17 09:14 Сейчас в теме
Вопрос.
Переношу данные из УТ 10.3.13.2 в БП 2.0.13 в режиме совместимости.
Пытаюсь выгружать все через обработку "Универсальный обмен данными в формате XML" версии 2.0.20."
Почему "Выгрузку необходимо производить через обработку "Универсальный обмен данными в формате XML" версии не ниже 2.1.7."?
5. anchovy 24 06.09.17 18:40 Сейчас в теме
(4) Потому что в процессе разработки изменялся формат файла правил. Используйте лучше версию обработки не ниже 2.1.8 и будет вам счастье.
6. user793598 08.09.17 13:28 Сейчас в теме
Спасибо.
В начале написано:
"В результате работы данных правил создается документ ВводНачальныхОстатков с заполненной табличной частью МПЗПриобретенные.
Описываемый алгоритм реализован в выгрузке только этого типа документов. Исходные данные берутся из регистра ПартииТоваровНаСкладах."

Пункты 2 - 6 относятся ПКО номенклатура. Там все понятно и просто в "Конвертация данных 2.1.8".

Непонятен пункт 7. Запутался.
Добавляю ПКО "ВводНачальныхОстатков", где источник "РегистрНакопленияЗапись.ПартииТоваровНаСкладах", а источник "ДокументСсылка.ВводНачальныхОстатков", там ищу ТЧ МПЗПриобретенные, в нем номенклатуру, и пытаюсь прописать в событии ПередВыгрузкой код. Не нахожу, где это сделать в Конвертации данных... См. скрин. Может быть это надо делать по-другому?
Можно приложить правильный скрин?
Прикрепленные файлы:
7. anchovy 24 08.09.17 15:58 Сейчас в теме
(6) Смотрите в правилах.
Прикрепленные файлы:
8. anchovy 24 08.09.17 16:02 Сейчас в теме
(6) У ПКО ВводНачальныхОстатков нет источника. Данные для заполнения документа определяются в ПВД. Опять таки смотрите правила, там есть все.
Прикрепленные файлы:
9. German_Tagil 43 13.10.21 13:36 Сейчас в теме
(8) Сделал для реализации - что-то переносится а вот табличная часть документа не создается
не придумал как ПКС написать для Реализации....
или там не надо ничего писать. данные вроде правильно переносятся
только при обращении к документу - пишет выберите форму
вроде и работает ....
Оставьте свое сообщение