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

28.05.10

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

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

Скачать файлы

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

 

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

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

 

Введение 


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

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

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

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

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

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

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

Именно поэтому в типовых конфигурациях на платформе «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 Конфигурации 1cv8 Бесплатно (free)

Уже не одна веб-страница исписана знаниями о дополнительных обработках, как создать, как подключить. Есть масса вариантов, как их можно отладить. Я разобрался в кишках работы библиотеки и покажу, как можно расширить возможности дополнительных отчетов, а также покажу удобный способ отладки.

07.02.2024    2351    YA_418728146    11    

40

Регистры накопления в 1С:КА2 и 1С:ERP для расчета НДФЛ, страховых взносов и взаиморасчетов с сотрудниками на январь 2024 года. Краткое описание

Зарплата Механизмы типовых конфигураций Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Комплексная автоматизация 2.х Россия Бухгалтерский учет НДФЛ Абонемент ($m)

Для расчета зарплаты и соответствующих налогов в конфигурациях 1С:КА2 и 1С:ERP используется 22 регистра накопления, 7 регистров сведений, 1 регистр расчета и бухгалтерские проводки. В таблице приведены названия этих регистров, указаны основные регистраторы и виды движений приход/расход. В описании приводится краткое функциональное назначение регистров в основных зарплатных процессах. Описание регистров родилось из черновиков при написании различных отчетов и обработок при эксплуатации 1С-овских конфигураций и исправлении ошибок по НДФЛ, взаиморасчетов с сотрудниками и прочих. Информация не претендует на полноценное описание работы регистров, скорее это дискуссионный материал. Но, возможно, кому-то пригодится и сократит время при подготовке отчетности за непростой (в плане учета зарплаты) 2023 год. А возможно, кто-то поделится своим опытом.

1 стартмани

10.01.2024    1015    6    2ncom    3    

8

Шаблоны новых объектов 1С для 1С:Бухгалтерии предприятия

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

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

28.12.2023    4831    mrXoxot    11    

99

Ключи аналитик учета в ЕРП, КА, УТ

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

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

08.11.2023    7047    ids79    25    

74

Распределение по базе среднего в ЗИКГУ 3.1

Зарплата Механизмы типовых конфигураций Платформа 1С v8.3 1С:Зарплата и кадры государственного учреждения 3 Россия Бюджетный учет Абонемент ($m)

Результат расчета начислений (отпуск, БЛ и т.д.) может распределятся по базе среднего заработка. У таких начислений на вкладке "Налоги, взносы, бухучет" стоит галка "По базе среднего заработка". Но бывают случаи, что данное распределение необходимо скорректировать.

1 стартмани

14.09.2023    445    2    Vlx    0    

1

Расширение типового механизма настройки заполнения бухгалтерской отчетности (на примере конфигурации 1С:ERP. Управление холдингом 3.1.8.15)

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

В статье приведен алгоритм доработок типового механизма настройки заполнения бухгалтерской отчетности на примере конфигурации 1С:ERP. Управление холдингом (3.1.8.15). Цель доработок - сделать процесс настроек более гибким и удобным для пользователей

11.09.2023    1928    ICL-Soft    3    

12

Разбор механизма "Настройки полей формы" в 1С:ERP. Управление холдингом

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

В данной статье я постараюсь разобрать механизм, который Вам может встретиться на просторах типовой конфигурации 1С:ERP. Управление холдингом. Я не могу гарантировать, что этот механизм не исключат из следующих версий конфигурации (как, собственно, и любой другой). К сожалению, мне не удалось найти его ни в одном модуле конфигурации "Библиотеки стандартных подсистем". Мне он показался интересным, и захотелось более детально во всем этом разобраться.

18.07.2023    2156    it_box    1    

7

Работа с контактной информацией. Часть 2

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

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

05.06.2023    6951    biimmap    4    

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

Внимание! При загрузке файлов через браузер Google Chrome (некоторые расширения) возможны проблемы, связанные с ошибкой самого браузера. Пожалуйста, для данной операции используйте любой другой браузер.
13. Abadonna 3958 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 240 30.05.10 21:16 Сейчас в теме
Мне понравилось, Молодцы.
16. Valerich 1633 31.05.10 08:40 Сейчас в теме
Интересно оформлено, но сколько нам ошибок трудных готовит.....

Во втором уроке жуть.....
1. паарметров в запросе было гораздо больше, чем показано. Хотя можно было в запросе обойтись и без них, наверное, через условия соединения.... не знаю, автору виднее.
2. Логика развесстого условия явно хромает....
что же будет дальше....
17. coach 102 31.05.10 09:30 Сейчас в теме
(16) Спасибо за отзыв!
По п.1 рекомендую ознакомится с теорией по виртуальным таблицам, все-так в общем случае условие необходимо накладывать на уровне параметров ВТ.
По п.2 Не совсем понятно о чем конкретно речь...
18. Valerich 1633 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 1633 31.05.10 11:23 Сейчас в теме
(20) по п. 2 интуиция подсказывает мне что вообще ничего не спишется, хотя в запросы глубоко не вникал и впечатление поверхностное... но пробовать самому все повторить нет времени...
интуиция основана на том, что вы получаете остатки для аналогов, входящих в тот же кластер, что и сама номенклатура (так кажется). если она не будет входить в кластер, то и остатков не увидит...

может быть я и не прав.
24. coach 102 31.05.10 13:08 Сейчас в теме
(21) Отлично, что вы это заметили..
Этот случай как раз описывается в 7-ом уроке.
Там и рассматривается способ решения проблемы - создание динамической коллекции.
19. Valerich 1633 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 файла битые ссылки
Прикрепленные файлы:
Оставьте свое сообщение