Оприходование товара на основании документа Возврат от покупателей

1. Jovi 11.06.20 15:25 Сейчас в теме
Конфигурация: Trade (10.3.29.1) (http://v8.1c.ru/trade/), версия: 8.3.11.2867, обычные формы.
Добрый день. Подскажите пожалуйста в следующем. Мне нужно создать обработку, с помощью которой я смогу создавать документы оприходования товара на основе не проведённого документа возврат от покупателей. То есть получать позиции и количество из документа возврат от покупателей плюс нужно рассчитать себе стоимость. То есть есть реализация проведённая, есть её не проведённый возврат. Нужно вместо возврат создать документ оприходования. Товар из регистра партии товаров на складах списывается через реализацию по принципу FIFO. Документ возврат от покупателей возвращает товар немного иначе, последний товар который был списан из реализации будет первым в возврате (ну и остальные партии по такому же принципу). То есть оприходование должно записывать партии в такой же очерёдности как документ возврат от покупателей. Подскажите, как реализовать.
Небольшие наработки:
ВЫБРАТЬ
	ВозвратТоваровОтПокупателяТовары.Номенклатура КАК Номенклатура,
	ВозвратТоваровОтПокупателяТовары.ДокументПартии КАК Реализация
ПОМЕСТИТЬ ЗапросПоВозврату
ИЗ
	Документ.ВозвратТоваровОтПокупателя.Товары КАК ВозвратТоваровОтПокупателяТовары
ГДЕ
	ВозвратТоваровОтПокупателяТовары.Ссылка = &ДокументВозврата
;

////////////////////////////////////////////////////////////­////////////////////
ВЫБРАТЬ
	ЗапросПоВозврату.Номенклатура КАК Номенклатура,
	ПартииТоваровНаСкладах.Количество КАК Количество,
	ПартииТоваровНаСкладах.Стоимость КАК Стоимость,
	ПартииТоваровНаСкладах.ДокументОприходования КАК ДокументОприходования
ИЗ
	ЗапросПоВозврату КАК ЗапросПоВозврату
		ЛЕВОЕ СОЕДИНЕНИЕ РегистрНакопления.ПартииТоваровНаСкладах КАК ПартииТоваровНаСкладах
		ПО ЗапросПоВозврату.Номенклатура = ПартииТоваровНаСкладах.Номенклатура
			И ЗапросПоВозврату.Реализация = ПартииТоваровНаСкладах.Регистратор

УПОРЯДОЧИТЬ ПО
	ДокументОприходования
Показать


Тестовый пример результата запроса:
Результат запроса
По теме из базы знаний
Найденные решения
9. Jovi 17.06.20 10:01 Сейчас в теме
Моё решение:
Процедура КнопкаВыполнитьНажатие(Кнопка)
	
	Запрос = Новый Запрос;
	Запрос.Текст = 
	"ВЫБРАТЬ
	|	ВозвратТоваровОтПокупателяТовары.Номенклатура КАК Номенклатура,
	|	ВозвратТоваровОтПокупателяТовары.ДокументПартии КАК Реализация,
	|	ВозвратТоваровОтПокупателяТовары.ЕдиницаИзмерения КАК ЕдиницаИзмерения
	|ПОМЕСТИТЬ ЗапросПоВозврату
	|ИЗ
	|	Документ.ВозвратТоваровОтПокупателя.Товары КАК ВозвратТоваровОтПокупателяТовары
	|ГДЕ
	|	ВозвратТоваровОтПокупателяТовары.Ссылка = &ДокументВозврата
	|;
	|
	|////////////////////////////////////////////////////////////­////////////////////
	|ВЫБРАТЬ
	|	ЗапросПоВозврату.Номенклатура КАК Номенклатура,
	|	ПартииТоваровНаСкладах.Количество КАК Количество,
	|	ЗапросПоВозврату.ЕдиницаИзмерения КАК ЕдиницаИзмерения,
	|	ПартииТоваровНаСкладах.Стоимость КАК Стоимость,
	|	ПартииТоваровНаСкладах.Склад КАК Склад
	|ИЗ
	|	ЗапросПоВозврату КАК ЗапросПоВозврату
	|		ЛЕВОЕ СОЕДИНЕНИЕ РегистрНакопления.ПартииТоваровНаСкладах КАК ПартииТоваровНаСкладах
	|		ПО ЗапросПоВозврату.Номенклатура = ПартииТоваровНаСкладах.Номенклатура
	|			И ЗапросПоВозврату.Реализация = ПартииТоваровНаСкладах.Регистратор
	|
	|УПОРЯДОЧИТЬ ПО
	|	Номенклатура,
	|	ПартииТоваровНаСкладах.ДокументОприходования УБЫВ
	|АВТОУПОРЯДОЧИВАНИЕ";
	
	Запрос.УстановитьПараметр("ДокументВозврата", ДокументВозврата);
	
	ВыборкаВыгрузка = Запрос.Выполнить().Выгрузить();          
	
	НовыйДокумент = Документы.ОприходованиеТоваров.СоздатьДокумент();
	
	Для каждого СтрокаДокументаВозврата Из ДокументВозврата.Товары Цикл
		
		Массив = ВыборкаВыгрузка.НайтиСтроки(Новый Структура("Номенклатура", СтрокаДокументаВозврата.Номенклатура));
		НеобходимоеКоличество = СтрокаДокументаВозврата.Количество; 
		
		Для каждого СтрокаМассива Из Массив Цикл
			
			ТабличнаяЧасть = НовыйДокумент.Товары.Добавить();
			ТабличнаяЧасть.Номенклатура 			= СтрокаМассива.Номенклатура;
			ТабличнаяЧасть.ЕдиницаИзмерения	= СтрокаМассива.ЕдиницаИзмерения;
			ТабличнаяЧасть.Коэффициент			= 1;    			  			
			
			Если НеобходимоеКоличество > СтрокаМассива.Количество Тогда
				НеобходимоеКоличество = НеобходимоеКоличество - СтрокаМассива.Количество;
				ТабличнаяЧасть.Количество 		= СтрокаМассива.Количество;
				ТабличнаяЧасть.Цена 					= СтрокаМассива.Стоимость / СтрокаМассива.Количество;
				ТабличнаяЧасть.Сумма 				= СтрокаМассива.Стоимость;
			Иначе  				
				ТабличнаяЧасть.Количество 		= НеобходимоеКоличество;
				ТабличнаяЧасть.Цена 					= СтрокаМассива.Стоимость / СтрокаМассива.Количество;
				ТабличнаяЧасть.Сумма				= ТабличнаяЧасть.Количество * ТабличнаяЧасть.Цена;
				НеобходимоеКоличество = 0;
				Прервать;
			КонецЕсли;
			
		КонецЦикла;		
		
	КонецЦикла;
	
	НовыйДокумент.Товары.Свернуть("Номенклатура, ЕдиницаИзмерения, Коэффициент, Цена, Сумма, Качество", "Количество");	
	НовыйДокумент.Дата											= ТекущаяДата();
	НовыйДокумент.Склад											= СтрокаДокументаВозврата.Склад;
	НовыйДокумент.ОтражатьВУправленческомУчете 	= Истина;
	НовыйДокумент.Организация 								= УправлениеПользователями.ПолучитьЗначениеПоУмолчанию(ПараметрыСеанса.ТекущийПользователь, "ОсновнаяОрганизация");	
	НовыйДокумент.Записать();
	
КонецПроцедуры
Показать
Остальные ответы
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
2. soft_wind 11.06.20 16:37 Сейчас в теме
Ну да все правильно!
То что продали, а возврат на основании реализации, то и оприходывайте обратно, без всяких пересчетов, те-же партия и цена
3. Jovi 11.06.20 16:48 Сейчас в теме
(2) Не проведённый возврат не имеет движений в регистрах. Поэтому я не могу посмотреть как партии товаров возвращаются.
4. soft_wind 11.06.20 16:57 Сейчас в теме
(3) Непроведенный возврат ссылается на проведенную Реализацию
(не понятно, а что мешает все по возврату сделать - проводки оприходвания?)
7. alex-l19041 8 12.06.20 09:11 Сейчас в теме
(3) можно провести возврат, скопировать его движения, отменить проведение...
5. Jovi 11.06.20 17:04 Сейчас в теме
Не проведенный возврат ссылается на проведенную Реализацию

Верно, я об этом писал в шапке.

(не понятно, а что мешает все по возврату сделать - проводки оприходования?)

Ну есть свои нюансы, которые требуют функционала, который я описал в шапке.
6. soft_wind 11.06.20 19:48 Сейчас в теме
(5)
Нужно вместо возврат создать документ оприходования.

а какой документ собираетесь использовать вместо возврата?

могут подойти Корректировка или Операция, просто отсторнируйте проводки Реализации на вернутое количество,
и товар вернете и остатки по реализации всегда под рукой будут (что бы нельзя было вернуть больше чем продано)
alex-l19041; +1 Ответить
8. Jovi 12.06.20 16:07 Сейчас в теме
(6) Нужно как то сделать грамотный отбор после запроса,в котором будут сравниваться строки одной таблицы (возвраты) и другой (партий). Ну и одновременно высчитывать нужное количество из таблицы партий в таблицу возвратов.
Запрос = Новый Запрос;
	Запрос.Текст = 
	"ВЫБРАТЬ
	|	ВозвратТоваровОтПокупателяТовары.Номенклатура КАК Номенклатура,
	|	ВозвратТоваровОтПокупателяТовары.Количество КАК Количество,
	|	ВозвратТоваровОтПокупателяТовары.ДокументПартии КАК Реализация,
	|	ВозвратТоваровОтПокупателяТовары.Склад КАК Склад,
	|	ВозвратТоваровОтПокупателяТовары.ЕдиницаИзмерения КАК ЕдиницаИзмерения
	|ПОМЕСТИТЬ ЗапросПоВозврату
	|ИЗ
	|	Документ.ВозвратТоваровОтПокупателя.Товары КАК ВозвратТоваровОтПокупателяТовары
	|ГДЕ
	|	ВозвратТоваровОтПокупателяТовары.Ссылка = &ДокументВозврата
	|;
	|
	|////////////////////////////////////////////////////////////­////////////////////
	|ВЫБРАТЬ
	|	ЗапросПоВозврату.Номенклатура КАК Номенклатура,
	|	ЗапросПоВозврату.Количество КАК КоличествоНоменклатурыВозврата,
	|	ПартииТоваровНаСкладах.Количество КАК Количество,
	|	ЗапросПоВозврату.ЕдиницаИзмерения КАК ЕдиницаИзмерения,
	|	ПартииТоваровНаСкладах.Стоимость КАК Стоимость,
	|	ЗапросПоВозврату.Склад КАК Склад
	|ИЗ
	|	ЗапросПоВозврату КАК ЗапросПоВозврату
	|		ЛЕВОЕ СОЕДИНЕНИЕ РегистрНакопления.ПартииТоваровНаСкладах КАК ПартииТоваровНаСкладах
	|		ПО ЗапросПоВозврату.Номенклатура = ПартииТоваровНаСкладах.Номенклатура
	|			И ЗапросПоВозврату.Реализация = ПартииТоваровНаСкладах.Регистратор
	|
	|УПОРЯДОЧИТЬ ПО
	|	Номенклатура,
	|	ПартииТоваровНаСкладах.ДокументОприходования УБЫВ
	|АВТОУПОРЯДОЧИВАНИЕ";
	
	Запрос.УстановитьПараметр("ДокументВозврата", ДокументВозврата);
	Выборка = Запрос.Выполнить().Выбрать(); 
	
	ТЗНоменклатурыВозврата	= ДокументВозврата.Товары.Выгрузить();
		
	Отбор = Новый Структура();
	Отбор.Вставить("Номенклатура", Выборка.Номенклатура);
	Строка = ТЗНоменклатурыВозврата.НайтиСтроки(Отбор);
Показать
9. Jovi 17.06.20 10:01 Сейчас в теме
Моё решение:
Процедура КнопкаВыполнитьНажатие(Кнопка)
	
	Запрос = Новый Запрос;
	Запрос.Текст = 
	"ВЫБРАТЬ
	|	ВозвратТоваровОтПокупателяТовары.Номенклатура КАК Номенклатура,
	|	ВозвратТоваровОтПокупателяТовары.ДокументПартии КАК Реализация,
	|	ВозвратТоваровОтПокупателяТовары.ЕдиницаИзмерения КАК ЕдиницаИзмерения
	|ПОМЕСТИТЬ ЗапросПоВозврату
	|ИЗ
	|	Документ.ВозвратТоваровОтПокупателя.Товары КАК ВозвратТоваровОтПокупателяТовары
	|ГДЕ
	|	ВозвратТоваровОтПокупателяТовары.Ссылка = &ДокументВозврата
	|;
	|
	|////////////////////////////////////////////////////////////­////////////////////
	|ВЫБРАТЬ
	|	ЗапросПоВозврату.Номенклатура КАК Номенклатура,
	|	ПартииТоваровНаСкладах.Количество КАК Количество,
	|	ЗапросПоВозврату.ЕдиницаИзмерения КАК ЕдиницаИзмерения,
	|	ПартииТоваровНаСкладах.Стоимость КАК Стоимость,
	|	ПартииТоваровНаСкладах.Склад КАК Склад
	|ИЗ
	|	ЗапросПоВозврату КАК ЗапросПоВозврату
	|		ЛЕВОЕ СОЕДИНЕНИЕ РегистрНакопления.ПартииТоваровНаСкладах КАК ПартииТоваровНаСкладах
	|		ПО ЗапросПоВозврату.Номенклатура = ПартииТоваровНаСкладах.Номенклатура
	|			И ЗапросПоВозврату.Реализация = ПартииТоваровНаСкладах.Регистратор
	|
	|УПОРЯДОЧИТЬ ПО
	|	Номенклатура,
	|	ПартииТоваровНаСкладах.ДокументОприходования УБЫВ
	|АВТОУПОРЯДОЧИВАНИЕ";
	
	Запрос.УстановитьПараметр("ДокументВозврата", ДокументВозврата);
	
	ВыборкаВыгрузка = Запрос.Выполнить().Выгрузить();          
	
	НовыйДокумент = Документы.ОприходованиеТоваров.СоздатьДокумент();
	
	Для каждого СтрокаДокументаВозврата Из ДокументВозврата.Товары Цикл
		
		Массив = ВыборкаВыгрузка.НайтиСтроки(Новый Структура("Номенклатура", СтрокаДокументаВозврата.Номенклатура));
		НеобходимоеКоличество = СтрокаДокументаВозврата.Количество; 
		
		Для каждого СтрокаМассива Из Массив Цикл
			
			ТабличнаяЧасть = НовыйДокумент.Товары.Добавить();
			ТабличнаяЧасть.Номенклатура 			= СтрокаМассива.Номенклатура;
			ТабличнаяЧасть.ЕдиницаИзмерения	= СтрокаМассива.ЕдиницаИзмерения;
			ТабличнаяЧасть.Коэффициент			= 1;    			  			
			
			Если НеобходимоеКоличество > СтрокаМассива.Количество Тогда
				НеобходимоеКоличество = НеобходимоеКоличество - СтрокаМассива.Количество;
				ТабличнаяЧасть.Количество 		= СтрокаМассива.Количество;
				ТабличнаяЧасть.Цена 					= СтрокаМассива.Стоимость / СтрокаМассива.Количество;
				ТабличнаяЧасть.Сумма 				= СтрокаМассива.Стоимость;
			Иначе  				
				ТабличнаяЧасть.Количество 		= НеобходимоеКоличество;
				ТабличнаяЧасть.Цена 					= СтрокаМассива.Стоимость / СтрокаМассива.Количество;
				ТабличнаяЧасть.Сумма				= ТабличнаяЧасть.Количество * ТабличнаяЧасть.Цена;
				НеобходимоеКоличество = 0;
				Прервать;
			КонецЕсли;
			
		КонецЦикла;		
		
	КонецЦикла;
	
	НовыйДокумент.Товары.Свернуть("Номенклатура, ЕдиницаИзмерения, Коэффициент, Цена, Сумма, Качество", "Количество");	
	НовыйДокумент.Дата											= ТекущаяДата();
	НовыйДокумент.Склад											= СтрокаДокументаВозврата.Склад;
	НовыйДокумент.ОтражатьВУправленческомУчете 	= Истина;
	НовыйДокумент.Организация 								= УправлениеПользователями.ПолучитьЗначениеПоУмолчанию(ПараметрыСеанса.ТекущийПользователь, "ОсновнаяОрганизация");	
	НовыйДокумент.Записать();
	
КонецПроцедуры
Показать
Оставьте свое сообщение

Для получения уведомлений об ответах подключите телеграм бот:
Инфостарт бот