gifts2017

Замена единицы хранения остатков (алгоритм)

Опубликовал Константин Палецкий (konst_pal) в раздел Программирование - Практика программирования

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

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

Когда это пара документов, недавно введенных, здесь все ясно: отменяем проведение документов, меняем единицу хранения остатков, перезаполняем документы и проводим их. Но когда документов более сотни, да еще в закрытом периоде, в который лезть нельзя? Заводить новую номенклатуру - теряем данные по продажам.

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

Но предварительно рассмотрим пример из реальной жизни.

Номенклатура (назовем ее «Строительный материал»), как правило, поставщиком продается в метрах кубических, да и заказчик, делая заявку, тоже оперирует кубическими метрами.

Пользователи, естественно, ввели Базовую единицу – м3.

Единица хранения остатков сформировалась как м3 и Коэффициент = 1; (напомню, что коэффициент это количество Базовых единиц в одной единице измерения). Но все дело в том, что данный стройматериал поставляется в паллетах по 10 упаковок по 15 листов в упаковке. Каждый лист имеет размеры 1100х580х55 мм. Соответственно на складе кладовщики реально оперируют не метрами кубическими, а паллетами, упаковками, а потом еще и в розницу стали листами отгружать. Исходя из этого логично было сделать единицей хранения остатков - «Лист», как минимальную единицу измерения.

Но что было сделано в итоге:

Наименование

Коэфф.

  1.  

М3

1

  1.  

Лист

0,03509

  1.  

Упаковка

0,52635

  1.  

Паллет

5,2635

 

Из примера видно, что разрядность у «Коэфф» после нуля достигает 5 знаков. В типовом решении разрядность коэффициента только три разряда после запятой, но если их отбросить, то некорректно будут считаться остатки. (В моем случае клиент пошел на то, что изменили разрядность, как количества, так и коэффициента до 6 знаков и внесли изменения в проведение документов).

Собственно, перед нами задача описать алгоритм перевода из метров кубических в листы и получить следующую картину:

Наименование

Коэфф.

  1.  

М3

28,498 (1/0,03509)

  1.  

Лист

1

  1.  

Упаковка

15

  1.  

Паллет

150

 

  1. Во всех записях регистров накопления и бухгалтерии по нашей номенклатуре изменяем количество. Для пересчета используем формулу: Количество(новое) = Количество(из регистра) *Коэфф (старой ед.хран.)/Коэфф(новой ед.хран.);
  2. Меняем в карточке Номенклатуры единицу хранения остатков на новую.
  3. Устанавливаем новую базовую ед. изм. из единицы хранения остатков.
  4. Пересчитываем коэффициенты всех ед. измерения номенклатуры по формуле: К = К / Кнов.ед.изм ;

Наименование

Коэфф.

  1.  

М3

1/0,03509 = 28,498

  1.  

Лист

0,03509/0,03509 = 1

  1.  

Упаковка

0,52635/0,03509 = 15

  1.  

Паллет

5,2635/0,03509 = 150

 

   5. Обновляем коэффициент в табличных частях документов (саму ед. изм. в документе не меняем, пересчетов количества не производим)

 

Для того, чтобы записывать без ошибок наборы записей регистров, объекты справочников и документов, устанавливаем признак ОбменДанными.Загрузка = Истина;

См. также

Подписаться Добавить вознаграждение

Комментарии

1. Андрей Карпов (karpik666) 15.11.15 14:21
Такая проблема решается комплектацией номенклатуры, а не исправлениями в закрытом периоде.
2. Константин Палецкий (konst_pal) 16.11.15 21:53
Комплектация не меняет единицу измерения.
3. Константин Палецкий (konst_pal) 16.11.15 21:53
(1) karpik666, Комплектация не меняет единицу измерения.
4. Андрей Карпов (karpik666) 17.11.15 04:35
(3) konst_pal, мда, комплектация меняет на другую номенклатуру с другой единицей измерения, поэтому, если нужно поменять единицу хранения остатков, то создается новая номенклатура с похожим названием и с нужной единицей измерения.
5. Константин Палецкий (konst_pal) 17.11.15 09:32
(4) karpik666, Тогда теряем статистику продаж, для торговых крупно-оптовых предприятий это может быть критично. Собственно из-за этого и появилась данная статья.
6. Александр Крынецкий (echo77) 18.11.15 08:13
Если есть готовая программа, которая работает как часы - почему бы и нет?
Комплектацией номенклатуры - да, проще
7. Вадим Никонов (V.Nikonov) 18.11.15 11:50
Увы, решение только за счет увеличения разрядности далеко не всегда проходит. При пересчете может вполне получиться коэффициент в виде периодической дроби!!!
Соответственно при пересчете количества будут возникать погрешности округления.
Например, после расхода остатка документом целиком, могут возникать остатки вроде 0.001 или наоборот -0.003 и т.п.

Следовательно, нужен ещё один пункт алгоритма - Подчистка остатков округления! С методическим решением на что относить эти погрешности?!
8. Вадим Никонов (V.Nikonov) 18.11.15 11:53
Я предпочитал не менять количество хранения остатков. Подменял Базовую единицу, Единицу для отчетов и Коэффициенты. И на практике бывали случаи, когда пересчитывать регистры совсем не приходилось...
Для написания сообщения необходимо авторизоваться
Прикрепить файл
Дополнительные параметры ответа