Сопоставь несопоставленное - пример работы с сопоставлением номенклатуры контрагентов

16.12.21

Функциональные - Документооборот и делопроизводство (СЭД)

Пример использования встроенных типовых конфигураций 1С, в которых есть механизмы сопоставления номенклатуры контрагентов из ЭДО с номенклатурой самой базы 1С.

Скачать исходный код

Наименование Файл Версия Размер
Внешняя обработка-пример по работе с сопоставлением номенклатуры
.epf 10,84Kb
27
.epf 1.0 10,84Kb 27 Скачать

В библиотеке электронных документов, которая встроена в ряд типовых конфигураций 1С, есть механизмы сопоставления номенклатуры контрагентов из ЭДО с номенклатурой базы 1С. Особенно интересно данный функционал представлен в обработке  «Сопоставление номенклатуры (БЭД)» (СопоставлениеНоменклатурыБЭД), где у пользователя даже есть возможность настроить точность поиска.

И когда появилась задача сопоставлять номенклатуру из чеков ФНС (для обработок по загрузке чеков: здесь и здесь), то пришлось разбираться как этот механизм можно использовать для решения прикладных задач, несвязанных с ЭДО.
На форму выносим кнопку с командой:
 

&НаКлиенте
Процедура СопоставитьНоменклатуру(Команда)

    ПоказатьСопоставлениеНоменклатуры();

КонецПроцедуры

И добавляем отредактированную (относительно исходной) процедуру:
 

&НаКлиенте
Процедура ПоказатьСопоставлениеНоменклатуры()

    НоменклатураДляСопоставления = Новый Массив;

    Владельцы = Новый Массив;
    НоменклатураКонтрагентовМассив = Новый Массив;
    НоменклатураДляСопоставления = НоменклатураПоВладельцам(Владельцы,НоменклатураКонтрагентовМассив);
    
    Если Не ЗначениеЗаполнено(НоменклатураДляСопоставления) Тогда
        ТекстСообщения = НСтр("ru = 'Сопоставление номенклатуры не требуется.'");
        ПоказатьПредупреждение(, ТекстСообщения);
        Возврат;
    КонецЕсли;

    ДополнительныеПараметры = Новый Структура("НоменклатураДляСопоставления", НоменклатураДляСопоставления);
    ОбработкаЗавершения = Новый ОписаниеОповещения("ОбработатьСопоставлениеНоменклатуры", ЭтотОбъект, ДополнительныеПараметры);
    
    СопоставлениеНоменклатурыКонтрагентовКлиент.ОткрытьСопоставлениеНоменклатуры(НоменклатураДляСопоставления, , ОбработкаЗавершения);
    
КонецПроцедуры


Вставляем две функции по предварительному заполнению массивам, который будет передан для сопоставления. Запрос в функции «НоменклатураКонтрагентовНаКонтроле» изменён относительно первоначального.
 

&НаСервере
Функция НоменклатураПоВладельцам(Владельцы, НоменклатураКонтрагентовМассив)

    Возврат НоменклатураКонтрагентовНаКонтроле(Владельцы, НоменклатураКонтрагентовМассив);

КонецФункции

&НаСервере
Функция НоменклатураКонтрагентовНаКонтроле(Владельцы, НоменклатураКонтрагентовМассив)
    
    Запрос = Новый Запрос;
    Запрос.Текст =
    "ВЫБРАТЬ
    |    ТЗПокупки.НазваниеТовара КАК Наименование,
    |    ТЗПокупки.Контрагент КАК Владелец,
    |    ТЗПокупки.НомерСтроки КАК НомерСтроки
    |ПОМЕСТИТЬ ВТ
    |ИЗ
    |    &ТЗПокупки КАК ТЗПокупки
    |;
    |
    |////////////////////////////////////////////////////////////////////////////////
    |ВЫБРАТЬ
    |    ВТ.Наименование КАК Наименование,
    |    ВТ.Владелец КАК Владелец,
    |    ВТ.НомерСтроки КАК Идентификатор,
    |    ВТ.НомерСтроки КАК ИдентификаторНоменклатуры,
    |    ВТ.НомерСтроки КАК НомерСтроки
    |ИЗ
    |    ВТ КАК ВТ";

    НаборНоменклатурыКонтрагентов = Новый Массив;
        
    ТЗПокупки = Объект.Покупки.Выгрузить();
    Запрос.УстановитьПараметр("ТЗПокупки",ТЗПокупки);
    Выборка = Запрос.Выполнить().Выбрать();
    
    Пока Выборка.Следующий() Цикл
        
        НоменклатураКонтрагента = СопоставлениеНоменклатурыКонтрагентовКлиентСервер.НоваяНоменклатураКонтрагента();
        
        НоменклатураКонтрагента.Вставить("НомерСтроки","");
        
        ЗаполнитьЗначенияСвойств(НоменклатураКонтрагента, Выборка);
        
        ИдентификаторНоменклатуры = СтрЗаменить(НоменклатураКонтрагента.Наименование," ","");
        НоменклатураКонтрагента.Идентификатор = ИдентификаторНоменклатуры + "##";
        НоменклатураКонтрагента.ИдентификаторНоменклатуры = ИдентификаторНоменклатуры;
        
        НаборНоменклатурыКонтрагентов.Добавить(НоменклатураКонтрагента);
        
    КонецЦикла;
    
    Возврат НаборНоменклатурыКонтрагентов;
    
КонецФункции

 
Добавляем процедуру завершения (в которой добавлен небольшой цикл обработки полученного в результате сопоставления массива «Результат»):
 

&НаКлиенте
Процедура ОбработатьСопоставлениеНоменклатуры(Результат, ДополнительныеПараметры) Экспорт
    
    Если Не Результат = Неопределено Тогда
		Для Итератор = 0 По Результат.Количество()-1 Цикл
			
			НоменклатураИзЧека = Результат[Итератор].НоменклатураКонтрагента.Наименование;
			НоменклатураИзБазы = Результат[Итератор].НоменклатураКонтрагента.НоменклатураИБ;
			
			ПараметрыОтбора = Новый Структура;
			ПараметрыОтбора.Вставить("НазваниеТовара", НоменклатураИзЧека);
			НайденныеСтроки = Объект.Покупки.НайтиСтроки(ПараметрыОтбора);
			
			Для каждого НайденнаяСтрока из НайденныеСтроки Цикл
				НайденнаяСтрока.Номенклатура = НоменклатураИзБазы;								
			КонецЦикла;
            
		КонецЦикла;
	КонецЕсли;
    
КонецПроцедуры

Представленный код можно взять и применить в своём решении. Если нет времени на самостоятельную разработку, то можно воспользоваться уже готовым решением.

Пример использования (на основании приложенной к публикации обработки). Имеется три названия товара, принадлежащие двум контрагентам. Следует сопоставить эти названия с номенклатурой из типовой «1С:Бухгалтерия предприятия, редакция 3.0». Убеждаемся, что во всех строках есть названия товара и указаны контрагенты и вызываем команду «Сопоставить номенклатуру».


 

Открывается типовая форма «Сопоставление номенклатуры», где программа отражает уже имеющиеся элементы номенклатуры.


 

Или предлагает варианты сопоставления номенклатуры из базы.


 

При изменении точности поиска будут изменяться возможные варианты для сопоставления.


 

Если не все позиции номенклатуры сопоставить, то при нажатии на кнопку «Сохранить и закрыть» выйдет соответствующее сообщение. Сопоставленные позиции сохраняются в справочник «НоменклатураКонтрагентов» и регистр сведений «НоменклатураКонтрагентовБЭД», которые в пользовательском режиме отражаются одинаково как «Номенклатура контрагентов».


 

В результате в столбце «Номенклатура» отразится сопоставленная номенклатура.


 

Разработка и тестирование осуществлялись на типовой конфигурации «Бухгалтерия предприятия, редакция 3.0» (3.0.93.20) и платформе 1С:Предприятие 8.3 (8.3.18.1289).

Сопоставление номенклатуры СопоставлениеНоменклатурыБЭД

См. также

Автоматический заказ поставщику в 1С: загрузка прайсов и анализ цен поставщиков для УТ 10.3, УТ 11, КА2, УНФ, УПП, ERP, Розница 2

Бюджетирование и планирование Оптовая торговля Розничная торговля Логистика, склад и ТМЦ Анализ продаж Платформа 1С v7.7 Платформа 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Управление торговлей 10 1С:Розница 2 1С:Управление производственным предприятием 1С:Управление нашей фирмой 1.6 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Розничная и сетевая торговля (FMCG) Оптовая торговля, дистрибуция, логистика Беларусь Украина Россия Казахстан Управленческий учет Платные (руб)

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

28500 руб.

21.04.2017    91141    111    40    

199

1С:Документооборот - цена на лицензии КОРП, ПРОФ и ДГУ

Документооборот и делопроизводство (СЭД) Типовые Платформа 1С v8.3 Управленческий учет Платные (руб)

Организуйте правильный документооборот на вашем предприятии в 1С. Ведение учета и хранения документов. Управление потоками документации между подразделениями. Работа с договорами в компании. Автоматизация подготовки, согласования и подписания документов. Сократите время и объем ошибок с 1С:Документооборот!

48500 руб.

19.02.2016    107291    104    5    

86

Загрузка номенклатуры из Excel в УТ11, КА 2, ERP 2, Розница 2. Дополнительные реквизиты и сведения, характеристики, картинки, цены, остатки

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

Загрузка из файлов xls, xlsx, ods, csv, mxl в УТ11, КА 2, ERP 2, Розница 2. Задействованы все возможности конфигурации - заполнение реквизитов номенклатуры, дополнительных реквизитов и сведений, характеристики, доп.реквизиты и сведения характеристик. Дополнительные обработки для расширения возможностей.

10560 руб.

29.10.2014    211492    630    526    

446

AS WMS: автоматизация склада с адресным хранением с помощью ТСД

Логистика, склад и ТМЦ Платформа 1С v8.3 Россия Платные (руб)

Подсистема управления складом AS WMS для конфигураций на платформе 1С 8. AS WMS – готовое решение для эффективного управления адресным складом. Внедрение системы AS WMS способствует быстрому отбору товара, ускорению инвентаризации, снижению зависимости от персонала, исключению пересорта. AS WMS встраивается в любую конфигурацию на платформе 1С 8 и работает как единая система без обменов. В учетной системе нет необходимости менять процессы под AS WMS (например, вводить ордерную схему), AS WMS использует стандартные документы по товародвижению вашей учетной системы.

40000 руб.

26.07.2023    3716    14    0    

11

Модуль "Ответственное хранение" или фулфилмент (FBS / FBO) для 1С:УТ 11.5, КА 2.5, ERP 2.5

Логистика, склад и ТМЦ Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Оптовая торговля, дистрибуция, логистика Управленческий учет Платные (руб)

Модуль "Ответственное хранение" для 1С (УТ 11.5, КА 2.5, ERP 2.5) позволяет организовать учет ответственного хранения товаров с весовыми характеристиками, в том числе со сроком годности и личным кабинетом Поклажедателя. Модуль реализован в виде расширения конфигурации, устанавливается в режиме 1С:Предприятие 8 за 5 минут по инструкции, что позволяет оставить конфигурацию 1С на стандартной поддержке и продолжать получать стандартные обновления от фирмы "1С".

60000 руб.

09.06.2020    35031    27    57    

54

Загрузка номенклатуры c картинками (несколько потоков одновременно) и сопутствующими данными в базу и любые документы из yml, xls, xlsx, xlsm, ods, ots, csv для УТ 10.3, УТ 11 (все), БП 3, КА 2, ERP 2, УНФ 1.6/3.0, Розница 2

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

Эволюция не стоит на месте - новая удобная версия функциональной обработки для Вашего бизнеса! Что же Вы получаете? Удобный и интуитивно понятный интерфейс с 3-мя этапами работы. 2 режима - автоматический и ручной. Чтение XLSX, XLSM, CSV, XML/YML форматов без офиса, на любом сервере! Визуальное связывание колонок файла и реквизитов простым перетаскиванием колонок. Создание или обновление номенклатуры с иерархией, характеристик, доп. реквизитов, упаковок, загрузка практически неограниченного количества картинок на одну номенклатуру (с возможностью загрузки в несколько потоков одновременно), с хранением в томах или в базе. Загрузка номенклатуры поставщиков или поиск по их данным номенклатуры. Загрузка доп. реквизитов в характеристики. Загрузка штрихкодов с генерацией новых. Создание элементов справочников и ПВХ "на лету" для выбранных реквизитов. (Обновление от 09.04.2024, версия 9.9 - 9.10)

14400 руб.

20.11.2015    151616    367    376    

503
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. RustIG 1615 24.05.21 08:07 Сейчас в теме
(0) плюс за идею! до такого еще надо додуматься! в реализацию не вникал, но ход мысли вроде как понятен.
2. baldorc 4 29.12.21 10:19 Сейчас в теме
В УТ11 в таблице покупки нужно поправить тип реквизита товары на ОпределяемыйТип.ВладелецНоменклатурыБЭД. Иначе будет ошибка типов при попытке сохранить сопоставление.
3. user1534170 07.05.22 07:12 Сейчас в теме
В УТ 11 (11.4.14.105) "Сопоставление номенклатуры" не находит даже номенклатуру скопированную из нашей же базы. То есть не сопоставляет вообще ничего...
Scroudge; PanNataly; +2 Ответить
4. mixqn 17.06.22 16:45 Сейчас в теме
(3) а как выполнялось копирование? в режиме ОбменДанными.Загрузка = Истина?
6. Scroudge 3 21.06.23 15:15 Сейчас в теме
(4) я чё-то этот коммент не понял. в примере ТЧ заполняется руками, а потом инициируется запуск автомата сопоставления.
5. Scroudge 3 21.06.23 14:43 Сейчас в теме
(3) такая же история. не сопоставляет, при этом наименование, полностью идентичное есть в справочнике номенклатуры. конфиг УНФ 3.0.2
9. Scroudge 3 23.06.23 14:11 Сейчас в теме
(3) да, у меня помогло:
1. установка константы Использовать словарь сопоставления номенклатуры БЭД
2. в форме Сопоставление номенклатуры меню Ещё выбрать Перезаполнить словарь сопоставления

после этого заработало (это в УНФ 3,0,2)
11. aleksanders 01.11.23 11:06 Сейчас в теме
(9) Автору плюсанул, отличная идея! В УТ11 и УНФ константы и словарь одинаковые, работает все без проблем. Минусуют те, кто не разобрался. Номенклатуру контрагентов можно использовать для разных целей. С этой идеей кода для сопоставления номенклатур в разы меньше.
12. delta 660 01.11.23 11:20 Сейчас в теме
(11) Доброго дня!
Спасибо за плюс.
Тут вскрылся один интересный момент по сопоставлению номенклатуры в 1С:Бухгалтерии, по которому задали вопрос напрямую в 1С и получили следующий ответ:
Встроенный в конфигурацию 1С:Бухгалтерия (ред.3.0) механизм сопоставления номенклатуры поставщиков (используется для сервиса 1С:ЭДО при сопоставлении номенклатуры), производит сопоставление номенклатуры только по двум видам номенклатуры: ‘Товары’ и ‘Услуги’.
Интересно, а в УТ11 и УНФ тоже есть такие ограничения?
13. aleksanders 16.11.23 18:05 Сейчас в теме
(12)
Встроенный в конфигурацию 1С:Бухгалтерия (ред.3.0) механизм сопоставления номенклатуры поставщиков (используется для сервиса 1С:ЭДО при сопоставлении номенклатуры), производит сопоставление ...

А не знаю и смотреть некогда . У меня все - товар
7. Scroudge 3 21.06.23 15:18 Сейчас в теме
в общем, обработка интересная, но сопоставление совсем не работает.
если б работало, - следующий шаг - загрузка данных из ексель в тч и была бы бомба.
8. Scroudge 3 21.06.23 15:46 Сейчас в теме
нарыл такую штуку как словарь сопоставления и соответствующую константу.
может без них не работает.
на днях попробую - отпишу.
10. Scroudge 3 23.06.23 14:13 Сейчас в теме
для нормальной работы в УНФ 3,0,2 потребовалось
1. установка константы Использовать словарь сопоставления номенклатуры БЭД (через функции специалиста)
2. в форме Сопоставление номенклатуры меню Ещё выбрать Перезаполнить словарь сопоставления
(так заполняется регистр сопоставления)
Оставьте свое сообщение