Учет аналогов в 1С:Предприятии 8.2 - статья и 7 видео-уроков

28.05.10

Разработка - Механизмы типовых конфигураций

В этой статье мне хотелось бы поговорить о решении нетривиальных задач на платформе "1С:Предприятии 8".
Рассмотрим задачу учета аналогов, разберем варианты реализации.
Решение упрощенной задачи учета аналогов можно будет посмотреть в приложенных видео-уроках.
Видео-уроки можно также рассматривать как пример разработки на платформе "1С:Предприятие 8.2".
Полный текст статьи с картинками можно скачать в приложенном pdf-файле.
Также в самом конце pdf-статьи находятся альтернативные ссылки на скачивание видео-уроков, их можно использовать при низкой скорости скачивания с инфостарта.

Скачать файл

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

Наименование По подписке [?] Купить один файл
Статья с картинками в формате pdf
.pdf 117,04Kb
834
834 Скачать (1 SM) Купить за 1 850 руб.
1-ый видео-урок
.avi 8,65Mb
202
202 Скачать (1 SM) Купить за 1 850 руб.
2-ой видео-урок
.avi 9,97Mb
157
157 Скачать (1 SM) Купить за 1 850 руб.
3-ий видео-урок
.avi 8,12Mb
124
124 Скачать (1 SM) Купить за 1 850 руб.
4-ый видео-урок
.avi 5,83Mb
119
119 Скачать (1 SM) Купить за 1 850 руб.
5-ый видео-урок
.avi 4,16Mb
109
109 Скачать (1 SM) Купить за 1 850 руб.
6-ой видео-урок
.avi 10,88Mb
106
106 Скачать (1 SM) Купить за 1 850 руб.
7-ой видео-урок
.avi 10,58Mb
102
102 Скачать (1 SM) Купить за 1 850 руб.

 

Аналоги аналогов и их аналоги

Казалось бы, зачем убийце убивать
убийцу убийцы?!... но Донцову уже
было не остановить..(с) Интернет

 

Введение 


                Все мы знаем, что такое аналоги: взаимозаменяемые товары, с похожими ключевыми свойствами. Однако задача учета аналогов не является тривиальной по своей сути. Во-первых, аналоги не всегда являются взаимозаменяемыми. Помните уроки истории:  Вассал моего вассала — не мой вассал. Например, есть два вида обшивки – обычная и влагостойкая. Можно сказать, что влагостойкая является аналогом для обычной, но не наоборот! Таким образом, если покупателю потребуется мебель с обычной обшивкой, которой вдруг не окажется на складе, ее можно будет заменить на влагостойкую.

Также бывают случаи, когда аналогом одной позиции является несколько составляющих. Например, ноутбук можно заменить системным блоком, монитором, клавиатурой, мышкой и источником бесперебойного питания :). Иногда несколько позиций может заменяться на несколько других.

Аналоги можно использовать в нескольких целях (в зависимости от требований заказчика):

·         при списании (продаже или передаче в производственный цех) автоматически подставлять аналоги при нехватке основных позиций, указанных в документе;

·         после заполнения документа предоставлять возможность воспользоваться распределением недостающих позиций по аналогам;

·         в момент подбора номенклатуры в документ показывать остатки, как основных позиций, так и их аналогов.

Таким образом, задача учета аналогов должна на каждом предприятии решаться индивидуально.

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

 

Постановка задачи

               
                В этой статье я бы хотел рассмотреть решение следующего варианта учета аналогов: учет полной взаимозаменяемости номенклатуры. Например, пользователь указывает, что аналогом красного маркера является оранжевый, а аналогом оранжевого – желтый (см. рис. 1).

Рассматриваем максимально абстрактный пример, поскольку, если разбирать задачу на реальных примерах, например, из пищевого производства – для прочих отраслей это подсознательно означает «это все не про нас». Будем развивать абстрактное мышление.

 

 

Рис. 1. Аналоги, задаваемые пользователем

Система должна достроить связи: для красного маркера, аналогами являются и оранжевый и желтый (см. рис. 2, синие стрелки).

 

 

Рис. 2. Полная взаимозаменяемость номенклатуры

Будем считать, что ограничения на глубину уровней аналогов нет.

Аналоги будем использовать для автоматической подстановки при списании, в случае нехватки выбранных товаров. Например, на складе есть 10 красных, желтых и оранжевых маркеров. При попытке списать (переместить в производство, продать) 25 красных маркеров должно списаться 10 красных, 10 оранжевых и 5 желтых, либо 10 красных, 10 желтых и 5 оранжевых. Последовательность списания аналогов должна определяться приоритетом.

Цель статьи – показать механизмы работы с взаимозаменяемыми аналогами. Данный вариант использования аналогов выбран по причине простоты реализации.

                В этой статье не хотелось углубляться математику: теорию графов и так далее. Рассмотрим решение задачи в информационной системе «1С:Предприятие 8».

 

Варианты решения

Вариант жестокий


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

 

Вариант прямолинейный


                Первое что приходит в голову – нужно для начала описать основные пары аналогов, а потом их как-то обрабатывать. Например, пары для маркеров – «Красный-Оранжевый» и «Оранжевый-Желтый». Давайте пойдем по этому пути. Аналоги удобно описать в регистре сведений с двумя измерениями «Номенклатура» и «Аналог», и двумя ресурсами: количество исходной номенклатуры и количество аналога. Самое сложное сделать обработку этих данных – достроить все отсутствующие связи. Для этого нужно для каждого товара определить список его аналогов, и для каждого аналога определить список его аналогов и так далее.  Налицо рекурсивный процесс. Но самое неприятное, что для каждого аналога нужно вычислять остатки, а это запрос к базе данных. И, как известно, запрос к БД в цикле (а любую рекурсию можно преобразовать в цикл) негативно сказывается на производительности системы.

                Кроме этого в данном варианте нужно следить за тем, чтобы не образовалось кольцо аналогов. Например, пары «Красный – Оранжевый», «Оранжевый – Желтый» «Желтый – Красный». Если подобные данные введет пользователь, то этот алгоритм зациклится.

 

Вариант правильный


                На самом деле решение задачи на поверхности. Ведь в постановке задачи все товары можно разделить на непересекающиеся группы (будем называть их кластерами). Каждый товар внутри кластера является взаимозаменяемым с любым товаром из этого же кластера (см. рис. 3).

 

Рис. 3. Кластеры аналогов

Таким образом, прежде чем браться за решение задачи нужно разработать структуру базы данных.

                Приведем шаги по реализации задачи.

1.       Прежде всего, потребуется справочник, описывающий кластеры. Реквизитов в этом справочнике не требуется, достаточно наименования. Называть кластеры можно по-разному, «Кластер 1», «Кластер 2» или «One», «Two». Следует учитывать, что кластеры создаются системой автоматически, поэтому осмысленные такие названия, как «Столы офисные», «Мебель плетеная» и т.д. вряд ли возможны. Можно применить интересный ход – в наименовании отображать названия товаров, входящих в кластер. То есть название кластера может выглядеть так «Табуретка на 4х ножках; Табуретка на 3х ножках; Табуретка на любителя (на одной ножке)». Такой подход будет удобен для пользователя: можно сразу представить какая номенклатура входит в кластер. Но следует помнить, что длина наименования в справочнике ограничена 150 символами, поэтому название может содержать лишь некоторые элементы, входящие в кластер.

2.       Создать объект, описывающий состав кластера (кластеры не должны пересекаться по товарам). Это, конечно же, регистр сведений. Какова будет его структура? Вспомним замечательное свойство регистра сведений – контроль уникальности записей        по всем измерениям и периоду. Поэтому структура должна быть следующей: измерение – номенклатура, ресурс – кластер.

3.       Документ, позволяющий определять аналоги. Именно этот документ будет определять (а в случае необходимости и создавать) кластер для пары «номенклатура-аналог». Также нужно учесть, что кластеры могут укрупняться. Например, есть пара аналогов маркеров «Синий - Фиолетовый» они задаются в своем кластере. Также существует кластер маркеров «Красный – Оранжевый – Желтый». Если завести еще одну пару аналогов «Фиолетовый - Оранжевый», то и синий маркер будет аналогом для красного.

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

Действительно, представленный алгоритм может показаться простым для реализации в платформе «1С:Предприятие 8». Но здесь есть подводный камень, который замечают не все разработчики.

                Представим, что в документе списываются следующие маркеры:

·         красный, 10 шт.

·         желтый 10 шт.

На остатках числятся маркеры:

·         красный, 5 шт.

·         желтый 5 шт.

·         оранжевый 9 шт.

В этом случае при обработке первой строки система спишет 5 шт. красных маркеров и 5 шт. оранжевых. И, теперь, главное при обработке второй строки запроса нужно учесть, что оранжевых маркеров осталось всего 4 штуки! То есть, нужно динамически отслеживать уже списанные остатки. Также нужно учитывать, что в приведенном примере желтый маркер является аналогом красного. Значит, может возникнуть ситуация, когда товар, который списывается в текущей строке, уже был списан ранее!

 

Приоритеты аналогов


                Рассмотрим еще один важный вопрос – последовательность списания аналогов. Допустим, что для красного маркера аналогами являются оранжевый и желтый. Какой товар должна взять система при нехватке красного маркера? Можно предположить, что должен быть приоритет, на который должна ориентироваться система. На самом деле, в реальной жизни все обстоит несколько сложнее. Система должна гарантировать, что редкий заменитель уйдет только на ту позицию, где он абсолютно необходим.

                Для учета приоритетов необходимо ввести понятие веса.

            Вес = Приоритет * К покрытия , где

Приоритет    определяется пользователем

 К покрытия  – коэффициент, учитывающий остатки аналога. То есть больший приоритет имееют те аналоги, которых достаточно много на складе.

 

Заключение


                После того, как была разобрана схема решения задачи, я рекомендовал бы вам выполнить реализацию на платформе «1С:Предприятие 8.2». Тем самым, вы получите полезный навык решения нетривиальных задач.

Если Вы тоже сталкиваетесь с задачами учета аналогов, например, иерархические аналоги, аналоги без полной взаимозаменяемости, условные аналоги и Вам интересно пообщаться на эту тему  – пишите на gilev@spec8.ru.

С уважением к вам, Евгений Гилев.

 

См. также

Механизмы типовых конфигураций Программист Платформа 1С v8.3 1C:Бухгалтерия Бесплатно (free)

Расчет себестоимости в типовых конфигурациях 1С – для многих «черный ящик», работающий по жестко зашитым в него алгоритмам. Реализация этого «черного ящика» может меняться в зависимости от конкретной конфигурации – УПП, БП 3.0, ERP. Но принцип работы везде одинаковый. Расскажем о том, как устроен расчет себестоимости, как его дорабатывать, и какие методы могут быть эффективны и без доработок.

27.12.2024    11352    Begemoth80    32    

85

СКД Механизмы типовых конфигураций Запросы Программист Платформа 1С v8.3 1С:Зарплата и кадры государственного учреждения 3 1С:Зарплата и Управление Персоналом 3.x Россия Бесплатно (free)

Работая с типовыми отчетами в конфигурациях «Зарплата и управление персоналом, редакция 3», «Зарплата и кадры государственного учреждения, редакция 3» и подобных, в схемах компоновки данных можно встретить конструкции запросов, которые обращаются к некоторым виртуальным таблицам.

20.08.2024    2416    PROSTO-1C    0    

21

Механизмы типовых конфигураций Программист Платформа 1С v8.3 1С:Комплексная автоматизация 2.х Россия Бесплатно (free)

Эта ошибка была обнаружена мной в типовой конфигурации 1С:Комплексная автоматизация 2 (2.5.16.115), БСП версия 3.1.9.302. Возникает она после того, как вы добавляете в расширение бизнес-процесс или задачу, выполняете обновление идентификаторов метаданных расширений, но ошибка при записи любого элемента справочника "Профили групп доступа" всё равно остаётся.

01.07.2024    2527    Vidz    0    

12

Механизмы типовых конфигураций Программист Платформа 1С v8.3 1C:Бухгалтерия Россия Бесплатно (free)

Очень часто в написании кода требуется обращаться к предопределённым значениям. Если идёт обращение к типовым предопределённым значениям, то проблем не возникает.

24.06.2024    1406    olja-ljaaa    0    

3
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. coach 102 28.05.10 12:27 Сейчас в теме
Ребята, уроки доступны для скачивания?
В заголовке статьи написано "...посмотреть и скачать все файлы (8)...".
А внутри вижу только 2 файла..
HramenkovDU; +1 Ответить
2. СергейКа 670 28.05.10 13:54 Сейчас в теме
(1) Вроде все файлы на месте
4. coach 102 28.05.10 19:05 Сейчас в теме
(2) Ок, видимо у меня браузер страницы закешировал
(3) Тема эта сильно интересная...
В статье я рассмотрел лишь базовые случаи, но как верно заметили, хотел обратить внимание на подводные камни.
Спасибо за положительный отзыв!
3. RailMen 829 28.05.10 16:22 Сейчас в теме
Это не простая тема: тут и методы оптимизации и теория графов и технолигические карты и куча другого. Хорошо, что некоторые подводные камни были вынуты со дна морского.
5. _LEV_ 28.05.10 19:55 Сейчас в теме
Спасибо, интересная статья. Про файлы не понятно, одним архивом можно положить видеоуроки?
6. coach 102 28.05.10 20:03 Сейчас в теме
(5) Пытался положить одним архивом, почему-то они не принимались сервером.
Завтра утром выложу материалы на другой сервер и дам ссылку...
7. alexk-is 6545 28.05.10 21:23 Сейчас в теме
(6) В IE zip выложить проблем не составляет. С другими браузерами периодически возникают проблемы.
9. coach 102 29.05.10 08:41 Сейчас в теме
(7) Понятно, значит может быть дело в том, что использую хром.
Спасибо.
11. Abadonna 3970 29.05.10 09:20 Сейчас в теме
(9) С хромом ИС точно не дружит, даже где-то на это ссылка была...
12. alexk-is 6545 29.05.10 10:21 Сейчас в теме
(11) В каждой публикации на закладке "Файлы" красным:

Внимание! При загрузке файлов через браузер Google Chrome (некоторые расширения) возможны проблемы, связанные с ошибкой самого браузера. Пожалуйста, для данной операции используйте любой другой браузер.
13. Abadonna 3970 29.05.10 10:30 Сейчас в теме
(12) Ага! Точно! Просто я обычно как-то не особо обращал на нее внимания, потому как хромом не пользуюсь
8. script 128 29.05.10 00:49 Сейчас в теме
1C Долго выкладывала на ИТС подсистему прогнозирования там как раз решается вопрос аналогов и как раз с помощью кластерного метода.
10. coach 102 29.05.10 08:41 Сейчас в теме
(8) Это уже есть на ИТС??
Нужно заглянуть, спасибо :)
14. coach 102 30.05.10 21:13 Сейчас в теме
(all)
Мне уже третий раз поступает жалоба на невысокую скорость скачивания видео с инфостарта.
Поэтому, видео-уроки выложили на наш зарубежный хостинг, ссылка на скачивание находится в pdf-файле.
15. ILM 241 30.05.10 21:16 Сейчас в теме
Мне понравилось, Молодцы.
16. Valerich 1637 31.05.10 08:40 Сейчас в теме
Интересно оформлено, но сколько нам ошибок трудных готовит.....

Во втором уроке жуть.....
1. паарметров в запросе было гораздо больше, чем показано. Хотя можно было в запросе обойтись и без них, наверное, через условия соединения.... не знаю, автору виднее.
2. Логика развесстого условия явно хромает....
что же будет дальше....
17. coach 102 31.05.10 09:30 Сейчас в теме
(16) Спасибо за отзыв!
По п.1 рекомендую ознакомится с теорией по виртуальным таблицам, все-так в общем случае условие необходимо накладывать на уровне параметров ВТ.
По п.2 Не совсем понятно о чем конкретно речь...
18. Valerich 1637 31.05.10 10:28 Сейчас в теме
(17) досмотрел до конца.... те ошибки вроде как исправлены, но остались вопросы....

1. мы слили 2 кластера воедино - пустой кластер остался мусором навеки....??
2. если номенклатура еще не входит не в один из кластеров - как будет выполняться списание?
3. с точки зрения пользователя логичнее было бы сначала списать ВСЮ основную номенклатуру какая есть, и только потом обращаться к аналогам. Иначе может возникнуть непонятка... в рамках видеоурока попробуйте списать 15 красных, 10 оранжевых и 6 желтых. Порграмма скажет, что не хватает 1-го желтого. При этом в остатках любой пользователь увидит 10 желтых..... и начнет задавать неудобные вопросы....., на которые неопытный программист будет пытаться объяснить логику списания, а опытный объявит фичей :)
vano-ekt; Bukaska; CratosX; +3 Ответить
20. coach 102 31.05.10 10:53 Сейчас в теме
(18) Отвечаю по пунктам.
Во-первых, не стоит рассматривать материал как законченное и эталонное решение.
Скорее это "рыба" и пища для размышлений.
1. На самом деле подход, описанный в статье имеет схожую реализацию с расширенной
аналитикой в УПП. Там тоже неиспользуемые ключи аналитики будут болтаться вечно...ну или почти вечно, пока внедренец не запустить обработку "Тестирование и исправление ключей аналитики".
Здесь предлагаю такой же подход - использовать специальную обработку.
2. Если не входит - хорошо, значит у нее нет аналогов, спишется только она, если хватит...
3. Да, думаю это верно, но опять же я не привожу окончательного решения...
По поводу одного желтого, точно заметили, фича ))
21. Valerich 1637 31.05.10 11:23 Сейчас в теме
(20) по п. 2 интуиция подсказывает мне что вообще ничего не спишется, хотя в запросы глубоко не вникал и впечатление поверхностное... но пробовать самому все повторить нет времени...
интуиция основана на том, что вы получаете остатки для аналогов, входящих в тот же кластер, что и сама номенклатура (так кажется). если она не будет входить в кластер, то и остатков не увидит...

может быть я и не прав.
24. coach 102 31.05.10 13:08 Сейчас в теме
(21) Отлично, что вы это заметили..
Этот случай как раз описывается в 7-ом уроке.
Там и рассматривается способ решения проблемы - создание динамической коллекции.
19. Valerich 1637 31.05.10 10:32 Сейчас в теме
В общем поставлю плюс, но скорее авансом.... Советую более тщательно прорабатывать все до начала демонстрации.... особенно логику работы системы

PS и включите же наконец автозавершение кода.... а то на совсем неопытного похожи....
22. пользователь 31.05.10 12:05
Сообщение было скрыто модератором.
...
23. пользователь 31.05.10 12:58
Сообщение было скрыто модератором.
...
25. пользователь 01.06.10 15:30
Сообщение было скрыто модератором.
...
26. lees 23.04.12 14:05 Сейчас в теме
Отличный материал!!! В свое время были задачи, например в отчете "Анализ точки заказа" учитывать аналоги номенклатуры, ну делал тривиальный вариант, т.е. учитывал аналоги первого уровня (те аналог аналога - уже не аналог). Ладно что заказчиков более-менее устраивало...
27. arktika1 07.07.12 20:18 Сейчас в теме
Скажите а есть готовые решения?
по описанной Ваме статье.
также мне кажется что действиетельно, нет смысла обединять почти похожие аналоги, он либо является аналогом, либо нет и если у него есть схожие свойства то лучше при не нахождении аналога предложить поиск по похожим свойствам номенклотуры. Но важно что бы при прописывании А = Б и Б = С сразу прописывалось что и С = А
иначе возникает проблема надо повторно потом отыскивать связи и писать их дополнительно,
а это большой объем работ
28. farkhod 14 06.09.16 12:37 Сейчас в теме
Одним архивом не скачать? По ссылке из PDF файла битые ссылки
Прикрепленные файлы:
Оставьте свое сообщение