- Альфа-Авто:. Редакция 4.1 (8.2). помогите победить характеристики номенклатуры
- Ввод остатков из файла — свертка табличной части
- Таблица значений
- Как можно создать новую таблицу значений?
- Как добавить новую колонку с определенным типом и заголовком?
- Как добавить новые строки?
- Как выгрузить результат запроса в таблицу значений?
- Как обойти в цикле все строки таблицы значений?
- Как сделать выборку строк в таблице значений с отбором?
- Как выполнить сортировку?
- Как вычислить итоги по колонке?
- Как сделать копию таблицы значений?
- Как свернуть таблицу значений по колонке и суммировать по количеству?
- Как найти строку в таблице значений по значению?
Альфа-Авто:. Редакция 4.1 (8.2). помогите победить характеристики номенклатуры
Добрый день! Пишу загрузку остатков номенклатуры в документ «Вводостатковтоваров «(Альфа-Авто: Автосалон+Автосервис+Автозапчасти. Редакция 4.1 (4.1.01.20), платформа 8.2 (8.2.14.533))из dbf-файла. Не получается победить загрузку в табличную часть, загружаю запчасти, в справочнике «ТипыНоменклатуры» стоит «Учет по характеристикам не ведется» , как это отразить в обработке, чтобы не было вот такой ругани : Заполняется накладная номер ПРН0001951 поставщик
При записи обнаружены ошибки :
Таблица значение колонки не заполнено ! Строка номер 1
Из-за возникших ошибок операция записи была отменена.
сама процедура:
Процедура ЗагрузкаИзДбф(Док)
Контрагент=справочники.Контрагенты;
Дог=справочники.ДоговорыВзаиморасчетов;
склад=справочники.СкладыКомпании;
Номенклатура=Справочники.Номенклатура;
Единица=справочники.ЕдиницыИзмерения;
ЕдиницаБ=справочники.КлассификаторЕдиницИзмерения;
Орг=справочники.Организации;
ФОрг=Орг.ПолучитьФормуВыбора();
орг=Форг.ОткрытьМодально();
БД= Новый XBase;
ИмяФ =»tov.dbf»;
Путь = «C:/temp»;
Если Не НайтиДБФ(Путь,ИмяФ) Тогда
выборФайла(ИмяФ);
Иначе
имяФ = путь+»/»+ИмяФ;
КонецЕсли;
БД.ОткрытьФайл(ИмяФ);
БД.Кодировка=КодировкаXBase.OEM;
//Флаг=1;
ТекНом=»»;
Для а=1 по БД.КоличествоЗаписей() Цикл
БД.Перейти(а);
Самномер=СтрЗаменить(БД.DOCNO, Символы.НПП, «»);
Если ТекНом<>Самномер Тогда
Док=Документы.ВводОстатковТоваров.СоздатьДокумент();
Док.Дата = БД.DOCDATE;
ВыборкаДог=Дог.Выбрать(,Док.Контрагент);
ВыборкаДог.следующий();
//Договор=ВыборкаДог.ПолучитьОбъект();
Сообщить(«Заполняется накладная номер «+ строка(Док.Номер)+» поставщик «);
//Док.ДоговорКонтрагента=Договор.Ссылка;
Док.Автор=Справочники.Пользователи.НайтиПоНаименованию(«Elegant», Истина);
Док.ХозОперация=Справочники.ХозОперации.ВводОстатковТоваров;
Док.ВалютаДокумента=Константы.ВалютаРегламентированногоУчетаОрганизаций.Получить();
Док.КурсДокумента=1;
КонецЕсли;
Док.СуммаДокумента=БД.SUMMA;
СтрокаДок=Док.Товары.Добавить();
СтрокаДок.Количество=БД.KOL;
СтрокаДок.Цена=БД.CENA ;
ТМЦ18=БД.kod;
Если Номенклатура.НайтиПоКоду(СокрЛп(ТМЦ18))=Справочники.Номенклатура.ПустаяСсылка()Тогда
ТОВАР = БД.NOM;
ПолнТовар=БД.NOMPL;
Един=БД.ED;
Сообщить(«Добавление номенклатуры» +ТОВАР);
НовыйТовар= Справочники.Номенклатура.СоздатьЭлемент();
// Получить ссылку на группу, в которой будет находиться новый элемент.
Родитель = Справочники.Номенклатура.НайтиПоНаименованию(«Материалы запчасти», Истина);
НовыйТовар.ВалютаУчета=справочники.Валюты.НайтиПоКоду(810);
НовыйТовар.Артикул=БД.KAT+1;
НовыйТовар.ставкандс=справочники.СтавкиНдс.НайтиПоНаименованию(«18%», Истина);
НовыйТовар.ТипНоменклатуры=справочники.ТипыНоменклатуры.НайтиПоНаименованию(«Материалы и спецоснастка»);
НовыйТовар.ВидНоменклатуры=перечисления.ВидыНоменклатуры.Товар;
КонецЕсли;
рекв=СтрЗаменить(«Номенклатура.Артикул», Символы.НПП, «»);
//СтрокаДок.СуммаНДС=БД.NDS;
СтрокаДок.ЕдиницаИзмерения=СтрокаДок.Номенклатура.ОсновнаяЕдиницаИзмерения;
Если СтрокаДок.Номенклатура.ТипНоменклатуры.ИспользованиеХарактеристик=3 Тогда
Источник
Ввод остатков из файла — свертка табличной части
Внимание! Данный форум является модерируемым.
Для получения к нему доступа необходимо зарегистрироваться или авторизоваться на сайте.
Цитата |
---|
При записи обнаружены ошибки : Таблица значения колонок не уникальны ! Строки: 2,3,4,5 Таблица значения колонок не уникальны ! Строки: 6,7 Таблица значения колонок не уникальны ! Строки: 8,9 Таблица значения колонок не уникальны ! Строки: 10,11,12,13,14 Из-за возникших ошибок операция записи была отменена. |
Я так понимаю, что надо сделать свертку табличной части по номенклатуре, при этом вычислить среднюю себестоимость.
Подскажите, пожалуйста, как это сделать в АА? есть ли какие-то штатные средства обойти этот момент?
В загружаемом документе порядка 5000 позиций и почти все из них — имеют записи по нескольку строк
P.S. в коде и на рисунке можгут строки не совпадать — выкинул кое-что для наглядности.
В подменю заполнить добавьте новую кнопку например «Свернуть табличную часть».
Сверните табличную часть следующей строкой:
Товары.Свернуть(«Номенклатура, ЕдиницаИзмерения, Коэффициент, СтавкаНДС, ХарактеристикаНоменклатуры, ГТД, ПроцентНаценки», «Цена, Количество, Сумма, СуммаВсего, СуммаНДС, ЦенаРозничная, СуммаРозничная»);
затем нужно пересчитать розничную цену.
И запустить обработчик
ОбработкаРеквизита(«Товары.Сумма», ТекущаяСтрока, ЭтаФорма);
Виктор Радько,
до свертки:
после свертки:
вопросы:
1)ОбработкаРеквизита(«Товары.Сумма», ТекущаяСтрока, ЭтаФорма); — это нужно для пересчета суммы
а для пересчета розничной цены, нужно знать сколько строк свернулось в текущую строку, чтобы получить «Цена=Цена/Кол.Строк.Свернутых». Как получить сколько строк свернулось в текущую строку? (именно не количество в колонке «количество», а количество свернутых строк по данной позиции)
2) может немножко не в тему: используется это же документ и эта же процедура загрузки из файла — есть проблема автоматической подгрузки «единицы измерения» — не могу настроить так, чтобы брало из файла или выставляло автоматом. как-то с этим можно бороться? может нужно ранее при загрузке номенклатуры создавать для неё «Единицы измерения»?
3) вопрос по ценам в данном документе(почитал хелп — немонятно) поле «Цена» — это грубо говоря «себестоимость» детали по которой она ложится на склад?
«Цена розничная» — я так понял что это должна быть цена по которой мы продаём в розницу или не так? если это так, то почему не подхватывается текущая розничная цена, установленная документом «Изменение цен компании» если это не реальная розничная цена — то данную колонку можно проигнорировать и использовать только колонку «Цена», для задания себестоимости товара на складе. Проясните, пожалуйста, ситуацию.
1.
ОбработкаРеквизита(«Товары.Сумма», ТекущаяСтрока, ЭтаФорма); нужна для получения цены и процента наценки.
цена розничная = Сумма розничная/количество товара, иначе можем получить большое расхождение между Суммой и ценой умноженной на количество.
2. Единицы нужно заранее загрузить лучше этой же обработкой. Одного наименования в табличной части документа мало, чтоб автоматически создавать не хватающие единицы.
3.
«Цена» — это грубо говоря «себестоимость».
«Цена розничная» — это цена учета на розничном складе, а не цена продажи. Тип розничной цены указывается в поле «Тип цен розничной торговли» у Склада документа, если он розничный. Можно розничную цену не подгружать, а брать из регистра сведений вот нужный вызов события
ОбработкаРеквизита(«УстановитьРозничнуюЦену», ТекущаяСтрока, ЭтаФорма);
Все зависит от того, что надо, оставить старую розничную цену или перебить ее подгружаемой. Чтоб перебить текущую цену у Подразделения должен быть установлен признак «Формировать цену розничной торговли».
Себестоимость хранится в регистре «Партии товаров компании», а розничная сумма в регистре «Остатки товаров компании».
Спасибо!
По ценам.
С ценами вроде понятно: что для чего и как лучше рассчитывать. Только уточню: я правильно понял, что можно только загрузить «Цену» как себестоимость, а «Розничную цену» не загружать совсем — если цены устанавливаются отдельным документом «изменение цен»?
или именно для этого документа нужно подгружать или брать из регистров розничную цену, чтобы правильно потом отображались отчеты?
По «Единицам Измерения».
Не совсем понятно, как это же обработкой загрузить единицы — крутил и так и эдак — не получается. мне для начала надо хотя бы просто всем позициям указать «шт».
Есть ли какой-то пример, как имея Список Номенклатуры(наименование, артикул — уникальный, если нужно — код в БД) — установить для «ввода остатков» единицы измерения «шт»?
Номенклатуру я гружу программно из excel-файла, кусок кода касательно единиц у меня такой:
Цитата |
---|
Александр Тугаенко пишет: я правильно понял, что можно только загрузить «Цену» как себестоимость, а «Розничную цену» не загружать совсем — если цены устанавливаются отдельным документом «изменение цен»? или именно для этого документа нужно подгружать или брать из регистров розничную цену, чтобы правильно потом отображались отчеты? |
Если для розничного склада не будут заданы розничные суммы (цены), то они не попадут в регистр «Остатки товаров компании». Искажаются данные для учета товаров розничного склада в продажных ценах, если не сделать переоценку товара, по ценам регистра сведений «Цены».
Розничные суммы вводятся не обязательно только в документе «Ввод остатков товаров». Они вводятся во всех документах оприходования товара.
Для загрузки единиц обработку «Загрузка данных из табличного документа» нужно запускать из подменю «Обработки» главного меню.
Спасибо за помощь!
Кому интересно, в результате делаю так:
1) загружаю Номенклатуру и и в процессе программно для каждой позиции «Основную единицу измерения» — НовыйЭлемент.ОсновнаяЕдиницаИзмерения = Справочники.ЕдиницыИзмерения.НайтиПоНаименованию(«шт»)
— получается для всех одинаковая и вроде какая-то виртуальная — до конца не понял .
2) Загружаю через обработку «Загрузка из табличного файла» — в справочник «единицы измерения» записи для каждой позиции номенклатуры.
3) программно изменяю у всей номенклатуры ОсновнуюЕдиницуИзмерения на загруженную на предыдущем шаге.
Теперь у всей номенклатуры ОсновнаяЕдиницаИзмерения=шт и для каждой — своя(в справочнике идут записи со связью по владельцу, в лице которого выступает Номенклатура) — т.к. надо будет потом устанавливать вес, то в качестве связи по владельцу использую Номенклатуру, а не ТипНоменклатуры.
4)В док. «Ввод остатков» через обработку «заполнить из файла» подгружаю остатки номенклатуры, при этом достаточно иметь(для меня): Артикул (уникальный у нас), Количество, Наименование ОсновнойЕдиницыИзмерения — шт, Цену(себестоимость). Остальное — выставляется или вычисляется.
5) после выполнения обработки в ТЧ «Ввод остатков» для всех строк прогоняю обработчик
ОбработкаРеквизита(«Товары.Сумма», ТекущаяСтрока, ЭтаФорма);
если этого не сделать — не пропишется себестоимость товара в регистры.
в результате получаю полный список Номенклатуры с остатками, себестоимостью остатков, и для каждой номенклатуры есть своя основная единицы измерения — на которую потом будет подвязываться вес.
P.S. свертку средствами 1С корректно сделать не получилось, а т.к. это надо будет сделать только 1 раз, то выгружаю xls-входные данные в MySQL — там запросом делаю что мне нужно, — выгружаю обратно в xls-файл и уже свернутый и полностью рассчитанный xls-файл гружу в обработку «Загрузка из табличного файла».
Для меня так получилось быстрее, чем докапываться до того как это делается в 1С.
Источник
Таблица значений
В таблицах значений существуют строки и колонки. У каждой строки есть индекс, он начинается с нуля. Таблицу значений можно создавать с различными колонками и добавлять в нее строки. По строкам в таблице можно делать выборку и поиск, устанавливать и получать значения, сортировать, группировать и удалять строки.
Как можно создать новую таблицу значений?
Как добавить новую колонку с определенным типом и заголовком?
- Имя (необязательный, тип Строка , по умолчанию пустая строка). Имя колонки.
- Тип (необязательный, тип ОписаниеТипов ). Объект, описывающий допустимые типы значений для колонки. Если параметр не указан, в колонке можно будет хранить значение любого типа.
- Заголовок (необязательный, тип Строка , по умолчанию пустая строка). Заголовок колонки таблицы значений. Используется при визуальном отображении таблицы значений.
- Ширина (необязательный, тип Число , по умолчанию ноль). Ширина колонки в символах. Используется при визуальном отображении таблицы значений.
Как добавить новые строки?
Как выгрузить результат запроса в таблицу значений?
Как обойти в цикле все строки таблицы значений?
Как сделать выборку строк в таблице значений с отбором?
- ПараметрыОтбора (обязательный, тип Структура ). Задает условия поиска: ключ структуры определяет имя колонки, по которой будет осуществляться поиск, а значение структуры — искомое значение.
Осуществляет поиск строк таблицы значений, отвечающих заданным условиям поиска. Возвращает массив строк таблицы значений, соответствующих условиям поиска. Метод эффективно использовать для выборки неуникальных значений.
Массив хранит ссылки на строки таблицы значений, то есть при изменении строки в таблице, значение в массиве тоже будет измененным.
Как выполнить сортировку?
Как вычислить итоги по колонке?
Как сделать копию таблицы значений?
Как свернуть таблицу значений по колонке и суммировать по количеству?
Метод Свернуть() сворачивает таблицу по колонке «Наименование» и суммирует колонку «Количество». Если существуют еще колонки, то они будут удалены.
- КолонкиГруппировок (обязательный, тип Строка ). Имена колонок, разделенные запятыми, по которым необходимо группировать строки таблицы значений.
- КолонкиСуммирования (необязательный, тип Строка ). Имена колонок, разделенные запятыми, по которым необходимо суммировать значения в строках таблицы значений.
Осуществляет свертку таблицы значений по указанным колонкам группировки. Строки, у которых совпадают значения в колонках, указанных в первом параметре, сворачиваются в одну строку. Значения этих строк, хранящиеся в колонках, указанных во втором параметре, накапливаются.
Списки колонок не должны пересекаться. Колонки, не вошедшие ни в один из списков колонок, после выполнения метода удаляются из таблицы значений.
- Если в колонке установлен тип и он единственный, то при суммировании будет предприниматься попытка преобразования значения к типу Число .
- Если колонке не присвоены типы, то в процессе суммирования будут принимать участие только значения, имеющие тип Число , значения других типов будут игнорироваться.
- Если в колонке несколько типов и среди них есть тип Число , то в процессе суммирования будут принимать участие только значения, имеющие тип Число , значения других типов будут игнорироваться.
- Если в колонке несколько типов и среди них нет типа Число , то результат суммирования будет 0, который будет присвоен в соответствующую колонку, где будет преобразован к значению по умолчанию для типа, установленного в колонке.
Как найти строку в таблице значений по значению?
- Значение (обязательный, тип Произвольный ). Искомое значение.
- Колонки (необязательный, тип Строка , по умолчанию пустая строка). Список имен колонок, разделенных запятыми, по которым производится поиск. Если параметр не указан, поиск осуществляется по всей таблице значений.
Осуществляет поиск значения в указанных колонках таблицы значений. Возвращает строку таблицы значений, в которой содержится искомое значение. Если значение не найдено, то возвращается значение Неопределено . Метод эффективно использовать для поиска уникальных значений.
Источник