УНФ. Партионный учет для списания материалов в документе "Сборка заказов". Версия 0.01

24.12.09

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

Документ заполняется материалами по спецификации, но графа партии не заполняется. Теперь под словом Партия 1с понимает чисто управленческий учет. Партия как качество или особенность номенклатуры. Поэтому даже не планируется списание этих управленческих партий каким либо автоматическим методом. Партию надо выбирать вручную ! Данная доработка заполняет табличную часть документа Сборка заказов по спецификации методом ФИФО.

Жду ваших комментариев и предложений по совершенствованию

Алгоритм пока не рабочий. Остатки по документу поступления (регистратору) не видны.

 

Документ заполняется материалами по спецификации, но графа партии не заполняется. Теперь под словом Партия 1с понимает чисто управленческий учет. Партия как качество или особенность номенклатуры. Поэтому даже не планируется списание этих управленческих партий каким либо автоматическим методом. Партию надо выбирать вручную ! Данная доработка заполняет табличную часть документа Сборка заказов по спецификации методом ФИФО.

 

Жду ваших комментариев и предложений по совершенствованию.

Алгоритм пока не рабочий. Остатки по документу поступления (регистратору) не видны.

 

  1. Изменил процедуру формы документа.

 

&НаСервере

// Процедура заполняет Запасы по спецификации.

//

Процедура ЗаполнитьПоСпецификацииНаСервере()

           

            Документ = РеквизитФормыВЗначение("Объект");

            Документ.ЗаполнитьТабличнуюЧастьПоСпецификации();

           

            //изменено нач

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

           

            Запрос = Новый Запрос;

    МенеджерВТ = Новый МенеджерВременныхТаблиц;

    Запрос.МенеджерВременныхТаблиц = МенеджерВТ;

           

            Запрос.УстановитьПараметр("Организация", Документ.Организация);

            Запрос.УстановитьПараметр("СтруктурнаяЕдиница", Документ.СтруктурнаяЕдиница);

            Запрос.УстановитьПараметр("СчетУчета", ПланыСчетов.Управленческий.СырьеИМатериалы);

            Запрос.УстановитьПараметр("МоментВремени", Документ.МоментВремени());

            Запрос.УстановитьПараметр("ТЗМатериаловДляСписания", ТЗМатериаловДляСписания);

           

            Запрос.Текст =

                        "ВЫБРАТЬ

                        |           ТЗ.Номенклатура КАК Номенклатура,

                        |           ТЗ.Количество КАК Количество,

                        |           ТЗ.ЕдиницаИзмерения

                        |ПОМЕСТИТЬ Номенклатурка

                        |ИЗ

                        |           &ТЗМатериаловДляСписания КАК ТЗ

                        |

                        |ИНДЕКСИРОВАТЬ ПО

                        |           Номенклатура";

            Запрос.Выполнить();

                       

            Документ.ЗапасыОчистить();

                       

            Запрос.Текст =

                        "ВЫБРАТЬ

                        |           МАКСИМУМ(ВложенныйЗапрос.КолДляСписания) КАК КолДляСписания,

                        |           ВложенныйЗапрос.Регистратор КАК Регистратор,

                        |           ВложенныйЗапрос.Номенклатура КАК Номенклатура,

                        |           ВложенныйЗапрос.Партия КАК Партия,

                        |           МАКСИМУМ(ВложенныйЗапрос.КоличествоКонечныйОстаток) КАК КоличествоКонечныйОстаток,

                        |           ВложенныйЗапрос.ЕдиницаИзмерения КАК ЕдиницаИзмерения

                        |ИЗ

                        |           (ВЫБРАТЬ

                        |                       МАКСИМУМ(ВложенныйЗапрос.Количество) КАК КолДляСписания,

                        |                       ЗапасыОстаткиИОбороты.Регистратор КАК Регистратор,

                        |                       ЗапасыОстаткиИОбороты.Номенклатура КАК Номенклатура,

                        |                       ЗапасыОстаткиИОбороты.Партия КАК Партия,

                        |                       МАКСИМУМ(ЗапасыОстаткиИОбороты.КоличествоКонечныйОстаток) КАК КоличествоКонечныйОстаток,

                        |                       ВложенныйЗапрос.ЕдиницаИзмерения КАК ЕдиницаИзмерения

                        |           ИЗ

                        |                       (ВЫБРАТЬ

                        |                                   Номенклатурка.Номенклатура КАК Номенклатура,

                        |                                   Номенклатурка.Количество КАК Количество,

                        |                                   Номенклатурка.ЕдиницаИзмерения КАК ЕдиницаИзмерения

                        |                       ИЗ

                        |                                   Номенклатурка КАК Номенклатурка) КАК ВложенныйЗапрос

                        |                                   ЛЕВОЕ СОЕДИНЕНИЕ РегистрНакопления.Запасы.ОстаткиИОбороты(, &МоментВремени, Регистратор, ДвиженияИГраницыПериода, Номенклатура В (&ТЗМатериаловДляСписания)) КАК ЗапасыОстаткиИОбороты

                        |                                   ПО ВложенныйЗапрос.Номенклатура = ЗапасыОстаткиИОбороты.Номенклатура

                        |          

                        |           СГРУППИРОВАТЬ ПО

                        |                       ЗапасыОстаткиИОбороты.Регистратор,

                        |                       ЗапасыОстаткиИОбороты.Номенклатура,

                        |                       ЗапасыОстаткиИОбороты.Партия,

                        |                       ВложенныйЗапрос.ЕдиницаИзмерения) КАК ВложенныйЗапрос

                        |

                        |СГРУППИРОВАТЬ ПО

                        |           ВложенныйЗапрос.Номенклатура,

                        |           ВложенныйЗапрос.Регистратор,

                        |           ВложенныйЗапрос.Партия,

                        |           ВложенныйЗапрос.ЕдиницаИзмерения

                        |ИТОГИ ПО

                        |           Номенклатура,

                        |           Регистратор,

                        |           Партия,

                        |           ЕдиницаИзмерения";

 

            //Запрос.УстановитьПараметр("Номенклатура", ТЗМатериаловДляСписания);

           

            Результат = Запрос.Выполнить();

 

           

            ВыбНом = Результат.Выбрать(ОбходРезультатаЗапроса.ПоГруппировкам);

            Пока ВыбНом.Следующий() Цикл

                       

                        Нужно = ВыбНом.КолДляСписания;

                       

                        ВыбРег = ВыбНом.Выбрать(ОбходРезультатаЗапроса.ПоГруппировкам);

                        Пока ВыбРег.Следующий() Цикл

                                  

                                   Если Нужно <=  0 Тогда

                                               Продолжить;   

                                   КонецЕсли;

                                  

                                   ВыбПартия = ВыбРег.Выбрать(ОбходРезультатаЗапроса.ПоГруппировкам);

                                   Пока ВыбПартия.Следующий() Цикл

 

                                               ВыбПартияЕдИзм = ВыбПартия.Выбрать(ОбходРезультатаЗапроса.ПоГруппировкам);

                                       ВыбПартияЕдИзм.Следующий();

                                              

                                               ДоступноДляСписания = ВыбПартияЕдИзм.КоличествоКонечныйОстаток;

                                               Если Нужно >  ДоступноДляСписания Тогда

                                                           Документ.ДобавляемСтрокуЗатратПартия(ВыбПартияЕдИзм,ДоступноДляСписания);

                                                           Нужно = Нужно - ДоступноДляСписания;        

                                               Иначе

                                                           //списываем остаток

                                                           ДоступноДляСписания = Нужно;

                                                           Документ.ДобавляемСтрокуЗатратПартия(ВыбПартияЕдИзм,ДоступноДляСписания);

                                                           Нужно = 0;

                                               КонецЕсли;

                                              

                                   КонецЦикла;

                                  

                        КонецЦикла;

                       

            КонецЦикла;

            //изменено Кон

           

            ЗначениеВРеквизитФормы(Документ, "Объект");

            Модифицированность = Истина;

           

 

КонецПроцедуры // ЗаполнитьМатериальныеЗатратыПоСпецификацииНаСервере()    

 

  1. Добавил свои процедуры в модуль документа

 

//изменено

Процедура ДобавляемСтрокуЗатратПартия(СтрокаВыборки, КолДляСписания) Экспорт

           

            НоваяСтрока = Запасы.Добавить();

                                  

            ЗаполнитьЗначенияСвойств(НоваяСтрока, СтрокаВыборки);

            НоваяСтрока.Количество = КолДляСписания;

           

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

 

Процедура ЗапасыОчистить() Экспорт

            Запасы.Очистить();

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

 

 

См. также

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

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

27.12.2024    11130    Begemoth80    32    

84

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

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

20.08.2024    2355    PROSTO-1C    0    

20

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

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

01.07.2024    2468    Vidz    0    

12

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

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

24.06.2024    1394    olja-ljaaa    0    

3
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. scanner1980 269 12.10.22 13:47 Сейчас в теме
хороший пример, только привязки к продукции нет в итоговой таблице запасы
Оставьте свое сообщение