[EnterpriseData] Антисвертка характеристик номенклатуры при выгрузке в Бухгалтерию

Публикация № 1012589

Разработка - Практика программирования

EnterpriseData КД 3 обмен данными универсальный формат УНФ 1.6 Бухгалтерия Характеристики

Рассмотрена выгрузка каждой пары значений Номенклатура - Характерстика из УНФ 1.6 в отдельную номенклатуру в Бухгалтерию 3.0 путём доработки правил обмена в формате EnterpriseData.

В данной статье описывается решения только для Конвертации данных версии 3. Аналогичная статья по КД 2 (не моя) здесь - infostart.ru/public/730593/

На одном из проектов возникла необходимость настроить обмен данными между конфигурациями УНФ и Бухгалтерия предприятия таким образом, чтобы каждая пара значений "Номенклатура-Характеристика" в УНФ соответствовала отдельной номенклатуре в Бухгалтерии.

Как известно при типовом обмене теряется такая аналитика учёта как "Характеристика" потому-что в Бухгалтерии просто-напросто отсутствует данное понятие.

Рассмотрим данную ситуацию для наглядности на простом примере. В УНФ есть номенклатура "Картофель фри" по которой заведено 3 характеристики - "Большой", "Средний", "Малый" и есть номенклатура "Картофель по-деревенски" по которой учёт по характеристикам не ведётся.

Если настроить обмен по умолчанию, то 2 номенклатуры из УНФ перегрузятся в 2 номенклатуры БП.

УНФ БП
Номенклатура Характеристика Номенклатура
Картофель фри Большой Картофель фри
Средний
Малый
--
Картофель по-деревенски -- Картофель по-деревенски

 

Но нам нужно добиться, чтобы 2 номенклатуры из примера из УНФ выгрузились в 5 (в данном случае) различных номенклатурных позиций в БП как в таблице ниже:

УНФ БП
Номенклатура Характеристика Номенклатура
Картофель Фри
Картофель Фри
Картофель Фри
Большой Картофель фри, Большой
Средний Картофель фри, Средний
Малый Картофель фри, Малый
-- Картофель фри
Картофель по-деревенски -- Картофель по-деревенски

 

По таблице видно, что одна номенклатурная позиция в базе УНФ превращается в N+1 номенклатурных позиций в БП, где N - количество характеристик у позиции в УНФ. Причина в том, что в УНФ при определённой настройке в карточке номенклатуры даже если включен учёт по характеристикам, то можно осуществлять операции с товаром по пустой характеристике:

Решим поставленную задачу.

Сразу оговоримся, что приведённое решение не универсально, а только частный случай применимый с рядом допущений:

1. Подразумевается, что в УНФ ведётся учет по характеристикам номенклатуры, а характеристики категорий не используются. То есть в УНФ у всех характеристик владельцем является справочник Номенклатура, а не справочник Категории Номенклатуры. Если это не так то необходимо немного другое решение, например создание регистра сведений с Измерениями Номенклатура и Характеристика и ресурсом УникальныйИдентификатор.

2. Используется односторонний обмен. (Выгрузка из УНФ в БП).

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

4. Сам процесс загрузки и редактирования правил в конфигурации конвертация данных 3.0 рассматривать не будем. Тут полностью стандартный процесс.

Итак, приступим:

Этап 1 - Редактируем правило обработки данных для выгрузки номенклатуры:

Для этого внесем изменения в правило обработки данных "Справочник_Номенклатура_Отправка" в событие "При обработке".

 

Суть изменений в том, что при выгрузке номенклатуры обходим все её характеристики и для каждой создаём структуру, которую заполняем данными на основе номенклатуры и характеристики. Созданную структуру выгружаем через типовую функцию ОбменДаннымиXDTOСервер.ВыгрузкаОбъектаВыборки().

Изменённое событие будет выглядеть в итоге так:

Процедура ПОД_Справочник_Номенклатура_Отправка_ПриОбработке(ДанныеИБ, ИспользованиеПКО, КомпонентыОбмена)
	ИспользованиеПКО.Справочник_Номенклатура_Отправка = Не ДанныеИБ.ЭтоГруппа;
	ИспользованиеПКО.Справочник_НоменклатураГруппа    = ДанныеИБ.ЭтоГруппа;
	
	Если Не ДанныеИБ.ЭтоГруппа
		И ЗначениеЗаполнено(ДанныеИБ.Родитель)
		И Не ОбъектСуществуетВБазе(ДанныеИБ.Родитель) Тогда
		ИспользованиеПКО.Справочник_Номенклатура_Отправка = Ложь;
	КонецЕсли;  
	
	// СТАРТ 	
	Запрос = Новый Запрос;
	Запрос.Текст =
	"ВЫБРАТЬ
	| ХарактеристикиНоменклатуры.Ссылка КАК Ссылка,
	| ХарактеристикиНоменклатуры.Код КАК Код,
	| ХарактеристикиНоменклатуры.Наименование КАК Наименование
	|ИЗ
	| Справочник.ХарактеристикиНоменклатуры КАК ХарактеристикиНоменклатуры
	|ГДЕ
	| ХарактеристикиНоменклатуры.Владелец = &Владелец";
	
	Запрос.УстановитьПараметр("Владелец", ДанныеИБ.Ссылка);
	
	РезультатЗапроса = Запрос.Выполнить();
	
	Выборка= РезультатЗапроса.Выбрать();
	
	Пока Выборка.Следующий() Цикл
		
		сткНоменклатура = Новый Структура();
		сткНоменклатура.Вставить("Ссылка",Выборка.Ссылка);
		сткНоменклатура.Вставить("ЭтоГруппа",Ложь);
		сткНоменклатура.Вставить("АлкогольнаяПродукция", ДанныеИБ.АлкогольнаяПродукция);
		сткНоменклатура.Вставить("Артикул", ДанныеИБ.Артикул);
		сткНоменклатура.Вставить("ЕдиницаИзмерения",ДанныеИБ.ЕдиницаИзмерения);
		сткНоменклатура.Вставить("ИмпортнаяАлкогольнаяПродукция", ДанныеИБ.ИмпортнаяАлкогольнаяПродукция);
		сткНоменклатура.Вставить("КатегорияНоменклатуры", ДанныеИБ.КатегорияНоменклатуры);
		сткНоменклатура.Вставить("Код",Выборка.Код);
		сткНоменклатура.Вставить("Комментарий", ДанныеИБ.Комментарий);
		сткНоменклатура.Вставить("Наименование",ДанныеИБ.Наименование + " " + Выборка.Наименование);
		сткНоменклатура.Вставить("ОбъемДАЛ", ДанныеИБ.ОбъемДАЛ);
		сткНоменклатура.Вставить("ПроизводительИмпортерАлкогольнойПродукции", ДанныеИБ.ПроизводительИмпортерАлкогольнойПродукции);
		сткНоменклатура.Вставить("Родитель", ДанныеИБ.Родитель);
		сткНоменклатура.Вставить("СтранаПроисхождения",ДанныеИБ.СтранаПроисхождения);
		сткНоменклатура.Вставить("ТипНоменклатуры",ДанныеИБ.ТипНоменклатуры );
		сткНоменклатура.Вставить("ВидАлкогольнойПродукции", ДанныеИБ.ВидАлкогольнойПродукции);
		сткНоменклатура.Вставить("СтавкаНДС", ДанныеИБ.СтавкаНДС);
		сткНоменклатура.Вставить("НаименованиеПолное", ДанныеИБ.НаименованиеПолное + " " + Выборка.Наименование);
		
		строкаПравил = КомпонентыОбмена.ПравилаОбработкиДанных.Найти("Справочник_Номенклатура_Отправка");
		
		ОбменДаннымиXDTOСервер.ВыгрузкаОбъектаВыборки(КомпонентыОбмена, сткНоменклатура, строкаПравил);
		
	КонецЦикла;
	// СТОП
КонецПроцедуры

Этап 2 - ПКО Спецификации номенклатуры.

Данное ПКО выделим отдельно, так как тут нестандартная по сравнению с остальными объектами метаданных ситуация - реквизит "Характеристика" присутствует как у самого справочника, так и его табличной части.

Для начала создадим Алгоритмы, которые будут создавать структуру из характеристики для дальнейшей выгрузки в ключевые свойства Номенклатуры. Также в этой функции будем генерировать реквизиты "Наименование" и "НаименованиеПолное".

 

Функция ПолучитьСтруктуруИзХарактеристикиИНоменклатуры(Номенклатура, Характеристика)
	стк = Новый Структура();
	стк.Вставить("Ссылка", Характеристика.Ссылка);
	стк.Вставить("Код", Характеристика.Код);  		         
	стк.Вставить("Наименование",Номенклатура.Наименование + ", " + Характеристика.Наименование);
	стк.Вставить("НаименованиеПолное", Номенклатура.НаименованиеПолное + ", " + Характеристика.НаименованиеДляПечати);
	стк.Вставить("Артикул", Номенклатура.Артикул); 
	Возврат стк;
КонецФункции

Далее создадим алгоритм для замены номенклатуры в таблицах значений:

Процедура ЗаменитьНоменклатуруХарактеристикой(ТабличнаяЧасть)
	
	ТабличнаяЧасть.Колонки.Добавить("НоменклатураСтруктурой");
	Для Каждого Строка Из ТабличнаяЧасть Цикл
		Если ЗначениеЗаполнено(Строка.Характеристика)  Тогда 
			Строка.НоменклатураСтруктурой = ПолучитьСтруктуруИзХарактеристикиИНоменклатуры(Строка.Номенклатура,Строка.Характеристика);			 
		Иначе
			Строка.НоменклатураСтруктурой = Строка.Номенклатура.Ссылка;	
		КонецЕсли;              
	КонецЦикла;
	ТабличнаяЧасть.Колонки.Удалить("Номенклатура");
	ТабличнаяЧасть.Колонки.НоменклатураСтруктурой.Имя = "Номенклатура";  
КонецПроцедуры

Теперь используя эти алгоритмы внесём изменения в само событие при отправке:

Процедура ПКО_Справочник_СпецификацииНоменклатуры_Отправка_ПриОтправкеДанных(ДанныеИБ, ДанныеXDTO, КомпонентыОбмена, СтекВыгрузки)
	Если СтекВыгрузки.Количество() > 1 Тогда
		Возврат;
	КонецЕсли;
	
	ДанныеXDTO.Вставить("Количество", 1);
	
	// СТАРТ
	Если ЗначениеЗаполнено(ДанныеИБ.ХарактеристикаПродукции) Тогда
		стк = ПолучитьСтруктуруИзХарактеристикиИНоменклатуры(ДанныеИБ.Владелец, ДанныеИБ.ХарактеристикаПродукции);
		ДанныеXDTO.Номенклатура.Ссылка = стк.Ссылка;	
		ДанныеXDTO.Номенклатура.КодВпрограмме  = стк.Код;	
		ДанныеXDTO.Номенклатура.Наименование  = стк.Наименование;	
		ДанныеXDTO.Номенклатура.НаименованиеПолное  = стк.НаименованиеПолное;		
	КонецЕсли;
	// СТОП
	
	Запрос = Новый Запрос;
	Запрос.Текст = 
	"ВЫБРАТЬ
	|	СпецификацииСостав.Номенклатура КАК Номенклатура,
	|	ВЫБОР
	|		КОГДА СпецификацииСостав.Количество = 0
	|			ТОГДА 1
	|		ИНАЧЕ СпецификацииСостав.Количество
	|	КОНЕЦ КАК Количество,
	|	ВЫБОР
	|		КОГДА СпецификацииСостав.ДоляСтоимости = 0
	|			ТОГДА 1
	|		ИНАЧЕ СпецификацииСостав.ДоляСтоимости
	|	КОНЕЦ КАК ДоляСтоимости,
	// СТАРТ
	|	СпецификацииСостав.Характеристика КАК Характеристика
	// СТОП
	|ИЗ
	|	Справочник.Спецификации.Состав КАК СпецификацииСостав
	|ГДЕ
	|	СпецификацииСостав.Ссылка = &Ссылка";
	
	Запрос.УстановитьПараметр("Ссылка", ДанныеИБ.Ссылка);
	
	ТаблицаСостав = Запрос.Выполнить().Выгрузить();
	// СТАРТ
	ЗаменитьНоменклатуруХарактеристикой(ТаблицаСостав);
	// СТОП
	
	Если ТаблицаСостав.Количество() > 0 Тогда
		ДанныеXDTO.Вставить("Товары", ТаблицаСостав);
	КонецЕсли;
КонецПроцедуры

Итак, ПКО готово. Так как в других справочниках, выгружаемых в EnterpriseData характеристики не используются переходим к документам.

Этап 3 - Подменяем номенклатуру при выгрузке по ссылке из документов.

Теперь нужно подменить номенклатура на характеристику во всех документах. После внимательного изучения правил обмена увидим, что данные по документам получаются с помощью алгоритмов, название которых  начинается с "ДанныеДокумента".

Всего их больше 30. К сожалению придётся для начала проверить каждый запрос в этих ПКО на наличие выбора поля "Характеристика" если выбирается поле "Номенклатура" и там где оно не выбирается - добавить.

После этого уже используем созданный нами алгоритм ЗаменитьНоменклатуруХарактеристикой(). Ниже приведён пример доработки для ДанныеДокументаАктВыполненныхРабот(). Все остальные функции редактируются аналогично. Все переработанные алгоритмы можно скачать во вложенном файле, который представляет из себя сохраненный в txt модуль "МенеджерОбменаЧерезУниверсальныйФормат". 

Функция ДанныеДокументаАктВыполненныхРабот(ДанныеИБ)
	Результат = Новый Структура;
		
		Запрос = Новый Запрос;
		Запрос.Текст = 
		"ВЫБРАТЬ
		|	АктВыполненныхРаботРаботыИУслуги.НомерСтроки КАК НомерСтрокиДокумента,
		|	АктВыполненныхРаботРаботыИУслуги.Номенклатура КАК Номенклатура,
		|	ВЫБОР
		|		КОГДА ТИПЗНАЧЕНИЯ(АктВыполненныхРаботРаботыИУслуги.ЕдиницаИзмерения) = ТИП(Справочник.ЕдиницыИзмерения)
		|			ТОГДА ВЫРАЗИТЬ(АктВыполненныхРаботРаботыИУслуги.Количество * АктВыполненныхРаботРаботыИУслуги.ЕдиницаИзмерения.Коэффициент КАК ЧИСЛО(15, 3))
		|		ИНАЧЕ АктВыполненныхРаботРаботыИУслуги.Количество
		|	КОНЕЦ КАК Количество,
		|	ВЫБОР
		|		КОГДА ТИПЗНАЧЕНИЯ(АктВыполненныхРаботРаботыИУслуги.ЕдиницаИзмерения) = ТИП(Справочник.ЕдиницыИзмерения)
		|				И АктВыполненныхРаботРаботыИУслуги.ЕдиницаИзмерения.Коэффициент > 0
		|			ТОГДА ВЫРАЗИТЬ(АктВыполненныхРаботРаботыИУслуги.Цена / АктВыполненныхРаботРаботыИУслуги.ЕдиницаИзмерения.Коэффициент КАК ЧИСЛО(15, 2))
		|		ИНАЧЕ АктВыполненныхРаботРаботыИУслуги.Цена
		|	КОНЕЦ КАК Цена,
		|	АктВыполненныхРаботРаботыИУслуги.Сумма КАК Сумма,
		|	АктВыполненныхРаботРаботыИУслуги.СтавкаНДС КАК СтавкаНДС,
		|	АктВыполненныхРаботРаботыИУслуги.СуммаНДС КАК СуммаНДС,
		|	ВЫБОР
		|		КОГДА АктВыполненныхРаботРаботыИУслуги.Номенклатура.СчетУчетаЗатрат <> ЗНАЧЕНИЕ(ПланСчетов.Управленческий.ПустаяСсылка)
		|				И (АктВыполненныхРаботРаботыИУслуги.Номенклатура.СчетУчетаЗатрат.ТипСчета = ЗНАЧЕНИЕ(Перечисление.ТипыСчетов.КосвенныеЗатраты)
		|					ИЛИ АктВыполненныхРаботРаботыИУслуги.Номенклатура.СчетУчетаЗатрат.ТипСчета = ЗНАЧЕНИЕ(Перечисление.ТипыСчетов.НезавершенноеПроизводство))
		|			ТОГДА ИСТИНА
		|		ИНАЧЕ ЛОЖЬ
		|	КОНЕЦ КАК ПроизводственныйРасход,
		|	ВЫБОР
		|		КОГДА ПОДСТРОКА(АктВыполненныхРаботРаботыИУслуги.Содержание, 1, 100) = """"
		|			ТОГДА АктВыполненныхРаботРаботыИУслуги.Номенклатура.НаименованиеПолное
		|	КОНЕЦ КАК Содержание,
		// СТАРТ
		|	АктВыполненныхРаботРаботыИУслуги.Характеристика КАК Характеристика
		// СТОП
		|ИЗ
		|	Документ.АктВыполненныхРабот.РаботыИУслуги КАК АктВыполненныхРаботРаботыИУслуги
		|ГДЕ
		|	АктВыполненныхРаботРаботыИУслуги.Ссылка = &Ссылка
		|;
		|
		|////////////////////////////////////////////////////////////////////////////////
		|ВЫБРАТЬ
		|	АктВыполненныхРаботПредоплата.Документ КАК Документ,
		|	АктВыполненныхРаботПредоплата.СуммаРасчетов КАК Сумма
		|ИЗ
		|	Документ.АктВыполненныхРабот.Предоплата КАК АктВыполненныхРаботПредоплата
		|ГДЕ
		|	АктВыполненныхРаботПредоплата.Ссылка = &Ссылка";
		
		Запрос.УстановитьПараметр("Ссылка", ДанныеИБ.Ссылка);
		РезультатыЗапроса = Запрос.ВыполнитьПакет();
		
		ТаблицаУслуги = РезультатыЗапроса[0].Выгрузить();
		ЗаполнитьСтавкиНДС_Отправка(ТаблицаУслуги);
		// СТАРТ
		ЗаменитьНоменклатуруХарактеристикой(ТаблицаУслуги);
		// СТОП
		Результат.Вставить("Услуги", ТаблицаУслуги);
		
		ПогашениеЗадолженности = Новый ТаблицаЗначений;
		ПогашениеЗадолженности.Колонки.Добавить("ДокументРасчетов");
		ПогашениеЗадолженности.Колонки.Добавить("Сумма");
			
		ВыборкаРасчеты = РезультатыЗапроса[1].Выбрать();
		Пока ВыборкаРасчеты.Следующий() Цикл
			ДокументРасчетов = Новый Структура("Значение, ИмяПКО", ВыборкаРасчеты.Документ, ИмяПКОДляДокумента(ВыборкаРасчеты.Документ));
			Если Не ЗначениеЗаполнено(ДокументРасчетов.Значение) 
				ИЛИ Не ЗначениеЗаполнено(ДокументРасчетов.ИмяПКО) Тогда
				Продолжить;
			КонецЕсли;
			СтрокаРасчеты = ПогашениеЗадолженности.Добавить();
			СтрокаРасчеты.ДокументРасчетов = ДокументРасчетов;
			СтрокаРасчеты.Сумма = ВыборкаРасчеты.Сумма;
		КонецЦикла;
		Результат.Вставить("ПогашениеЗадолженности", ПогашениеЗадолженности);
		
		Возврат Результат;
КонецФункции

 

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

Наименование Файл Версия Размер
МенеджерОбменаЧерезУниверсальныйФормат (выгрузка характеристик в отдельную номенклатуру)

.txt 1,16Mb
27.03.19
6
.txt 1,16Mb 6 Скачать

Специальные предложения

Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. sen_black 14.08.19 06:34 Сейчас в теме
Добрый день! а ПКО_Справочник_Номенклатура_Отправка_ПриОтправкеДанных не нужно еще поменять после изменений в ПДО_...?
2. user1130826 15.10.19 09:47 Сейчас в теме
Можете реализовать то же самое для УТ11 на заказ?
3. user1130826 16.10.19 02:21 Сейчас в теме
Уважаемый Владимир, автор темы, вы могли бы ответить мне на вопрос?
4. nforce 11 16.10.19 17:15 Сейчас в теме
(3)Добрый день. В личку к сожаление не отправляются сообщения. На данным момент ничего готового нет. Сделать можно - стоимость порядка 80 тысяч.
Оставьте свое сообщение

См. также

Переход на учёт по характеристикам для УТ, УНФ, Розница, КА Промо

Обработка справочников Оптовая торговля Розничная торговля Обработка документов WEB Управление торговлей Оптовая торговля Розничная торговля v8::ОУ v8::ПВХ Розница УНФ УТ11 КА2 Россия УУ Платные (руб)

Обработки предназначены для перевода баз 1С УТ 11.1-11.4 , УНФ 1.6, Розница 2.2, КА 2.4 ПРОФ на учёт по характеристикам. Публикация включает две обработки для каждой из конфигураций и руководства пользователя к обработкам: 1) «Создание номенклатуры с характеристиками». Обработка позволяет создать номенклатуру с характеристиками на основе нескольких позиций номенклатуры без характеристик. 2) «Замена номенклатуры на номенклатуру с характеристиками». Обработка позволяет заменить в объектах базы (документы, справочники, регистры, последовательности) исходную номенклатуру без характеристик на новую номенклатуру с характеристиками. Обработки предназначены для тех, кому необходимо быстро перевести рабочую базу на учёт по характеристикам для целей сокращения справочника номенклатуры и подготовки базы для интеграции с интернет-магазином на 1С-Битрикс.

5000 руб.

25.10.2016    34833    63    71    

Работа с хранилищем конфигурации из режима 1С: Предприятие минуя конфигуратор

Хранилище v8 1cv8.cf Абонемент ($m)

Описание приемов работы с хранилищем конфигурации 1С из режима 1С: Предприятие минуя конфигуратор. Статья содержит ряд примеров работы с хранилищем по протоколу HTTP, описание "внутренностей", а также демонстрационную обработку

3 стартмани

11.06.2020    5594    MaxxG    18    

История данных и БСП

БСП (Библиотека стандартных подсистем) v8 1cv8.cf Абонемент ($m)

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

1 стартмани

09.06.2020    3113    zeegin    15    

Telegram bot API - разбор документации с примерами

WEB v8 Абонемент ($m)

Перевод документации на язык 1С.

1 стартмани

06.04.2020    29670    leongl    43    

Безопасная работа с транзакциями во встроенном языке Промо

Практика программирования v8 1cv8.cf Абонемент ($m)

Разбираемся с опасностями использования транзакций во встроенном языке 1С. Познаем ошибку "В данной транзакции уже происходили ошибки". Учимся защищаться от них.

1 стартмани

25.03.2019    32900    tormozit    44    

Методика обновления формы объекта данных при изменении объекта

Практика программирования v8 v8::УФ 1cv8.cf Абонемент ($m)

В формах объектов данных часто встречаются элементы, косвенно связанные с объектом. Логику обновления этих элементов при изменении объекта обычно вызывают из обработчиков ПриСозданнииНаСервере и ПриОткрытии, забывая про наличие других способов изменения объекта. В статье предложена методика для обычных и управляемых форм, учитывающая все способы.

1 стартмани

09.03.2020    6764    tormozit    13    

Отправка уведомлений с помощью командной строки, Оповещения с сервера на клиент с помощью командной строки

Практика программирования v8 1cv8.cf Россия Абонемент ($m)

Отправка уведомлений с помощью команды командной строки msg. Оповестить пользователей из серверного модуля или регламентного задания, с помощью командной строки msg.

1 стартмани

05.03.2020    5006    user5300    3    

План подготовки к аттестации на 1С: Специалиста по платформе (+ Ссылки на материалы) Промо

Решение задач на 1С:Специалист v8 Россия Абонемент ($m)

Хочу поделиться собственным планом подготовки к аттестации на 1С: Специалист по платформе 8.3 со ссылками на материалы (и указанием стоимости).

1 стартмани

23.12.2017    21515    tmn72.1C    38    

Конвертация данных 2. Использование исходящих и входящих данных. Свойство "Получить из входящих данных"

Обмен данными 1С Перенос данных из 1C8 в 1C8 v8 КД Абонемент ($m)

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

17.02.2020    12198    Drivingblind    31    

Вывод сообщений в HTML поле средствами 1С

Практика программирования v8 v8::УФ Абонемент ($m)

Пример использования вывода большого количества сообщений в поле HTML. С возможностью открывать ссылочные объекты и создавать новые объекты передавая параметры прямо из HTML поля. Протестировано на релизах 8.3.12 и 8.3.15+

2 стартмани

31.01.2020    5152    burni4    16    

Краткое руководство по внесению изменений в конфигурацию

Практика программирования v8 1cv8.cf Абонемент ($m)

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

1 стартмани

13.01.2020    15838    sapervodichka    41    

Как выполнить отчет на СКД через COM и получить данные отчета? Промо

Практика программирования v8 УПП1 Россия Абонемент ($m)

Для чего это нужно. Например, нужно в одной базе получить какой-либо показатель из другой базы. Этот показатель вычисляется в каком-либо сложном отчете, который написан на СКД. Можно, конечно, "скопипастить" текст запроса из другой базы, немного подправить его и выполнять в том же COM подключении. Но с этим теряется гибкость: если отчет изменился, то нужно помнить о том, что где-то есть его "немного модифицированная" копия. В статье будет рассмотрен пример получения данных из базы ЗУП.

2 стартмани

08.05.2018    26527    wowik    3    

Разбираемся с web-kit в 1С, на примере интеграции TinyMCE в управляемую форму в УТ 11.4. Допиливаем обмен с сайтом в УТ 11.4

Обмен данными 1С Интеграция Адаптация типовых решений v8 v8::УФ УТ11 Абонемент ($m)

Многие уже знают, что в релизе платформы 8.3.14.1565, браузер Internet Explorer был заменен на Web-Kit, это на самом деле большой шаг вперед, но я уверен, многим, как и мне, пока не совсем понятно, что к чему. Возник опыт использования web-kit в 1С, вызова JS из 1С и вызова 1С из JS. Давайте вместе попробуем понять, чем одно отличается от другого, и заодно сделаем, что-нибудь полезное. Да и наверняка многим придется переписывать свои подобные поделки после обновления на новую платформу, так что надеюсь мой опыт окажется полезным.

2 стартмани

08.12.2019    7796    Бэнни    25    

Массовое изменение режима поддержки объектов конфигурации

Структура метаданных v8 1cv8.cf Абонемент ($m)

Что делать, если при сравнении/объединении конфигураций нужно изменить режим поддержки для большого количества объектов? Штатного механизма для выполнения подобной задачи в Платформе нет. Изменять режим для всей конфигурации? Описывается способ, позволяющий выполнить изменение режима только для нужных объектов.

1 стартмани

05.11.2019    3876    VKislitsin    6    

"Живые" картинки со Snap.SVG

Практика программирования WEB Работа с интерфейсом v8 Абонемент ($m)

В статье рассмотрен пример использования http-сервисов для визуализации данных

1 стартмани

24.10.2019    12793    blackhole321    7    

Как нарисовать граф на 1С Промо

Практика программирования v8 Абонемент ($m)

Описывается реализация на языке запросов 1С метода расположения вершин графа на плоскости, основанного на использовании электромеханической аналогии. При этом вершины графа представляются одноименными электрическими зарядами, дуги - пружинками. Силы взаимодействия вершин в этой системе переводят их из случайного начального в нужное конечное положение. Приведена обработка рисования графов "ГрафОграф", реализующая данный подход, показывающая также динамику процесса. Граф можно задать списком ребер вручную, выбрать из нескольких предопределенных примеров или сформировать по данным информационной базы.

1 стартмани

09.08.2013    69806    ildarovich    117    

Интеграция 1С с сайтом (магазином) WordPress (WooCommerce) с помощью Rest API сайта. Часть 1. Авторизация

WEB v8 Абонемент ($m)

Интеграция 1С с сайтом (магазином) WordPress (WooCommerce) с помощью функционала Rest API предоставляемого платформой (CMS) WordPress (WooCommerce). Без дополнительных приложений на PHP/вставьте сюда любой другой язык программирования/.

1 стартмани

12.10.2019    22232    osivv    31    

RLS - дубли условий в запросах к СУБД

Практика программирования Роли и права v8 v8::Права 1cv8.cf Абонемент ($m)

"Подводные камни", возникающие при бездумном копировании ролей с ограничениями RLS, как это отражается на производительности, разбор примера и инструмент для анализа.

1 стартмани

07.10.2019    8114    geron4    4    

Полезные процедуры и функции для программиста

Практика программирования Универсальные функции v8 1cv8.cf Россия Абонемент ($m)

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

1 стартмани

07.10.2019    27968    HostHost    40    

Простой способ индексирования интервалов Промо

Практика программирования v8 Абонемент ($m)

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

1 стартмани

28.09.2016    39016    ildarovich    22    

Вебхук. Путь Телеграма

Внешние источники данных Интеграция v8 Абонемент ($m)

Долгое (на самом деле нет) и нелегкое путешествие телеграма к неведомым (из за РКН) конфигурациям 1С. Памятка себе.

1 стартмани

03.10.2019    15881    platonov.e    18    

Многопоточная обработка данных на примере перепроведения документов

Обработка документов Практика программирования v8 ERP2 УТ11 КА2 Абонемент ($m)

Дальнейшее развитие темы фоновой обработки данных - проведение документов в потоках. Настройка параметров и запуск основного процесса (менеджера потоков). Разбивка документов для проведения на не связанные друг с другом наборы и запуск дополнительных фоновых заданий для отдельных потоков. Отслеживание выполнения каждого потока в родительском сеансе.

1 стартмани

17.09.2019    8620    ids79    46    

Описание формата внутреннего представления данных 1С в контексте обмена данными

Практика программирования Внешние источники данных v8 v8::УФ 1cv8.cf Абонемент ($m)

Фирма 1С не рекомендует использовать внутреннее представление данных для любых целей, которые отличны от обмена с 1С:Предприятием 7.7. Но сама возможность заглянуть на "внутреннюю кухню" платформы с помощью функций ЗначениеВСтрокуВнутр(), ЗначениеВФайл(), ЗначениеИзСтрокиВнутр() и ЗначениеИзФайла(), дала возможность сообществу программистов 1С разработать новые приемы разработки и анализа. Так, именно на использовании внутреннего представления был построен алгоритм "быстрого массива", который позволяет практически мгновенно создать массив в памяти на основании строки с разделителями. С помощью разбора внутреннего представления можно "на лету" программным кодом выполнить анализ обычной формы и даже сделать редактор графической схемы. Во внутреннем формате сохраняют свои данные между сеансами различные популярные внешние обработки. А еще это возможность сделать быстрый обмен с внешними системами.

1 стартмани

06.09.2019    18655    Dementor    30    

Бесплатная проверка контрагентов в ФНС (общий модуль с алгоритмом). На примере выводим статус в список справочника контрагентов Промо

Практика программирования v8 1cv8.cf Абонемент ($m)

Если вам интересно проверить контрагенте в ФНС, вам поможет данная публикация. Весь алгоритм работы строится на основе данных, полученных с сервиса http://npchk.nalog.ru совершенно бесплатно.

1 стартмани

01.02.2018    34547    rpgshnik    49    

1С и PowerShell - обновление из хранилища

Администрирование данных 1С Инструментарий разработчика v8 Абонемент ($m)

Пример скрипта, упрощающего работу.

1 стартмани

29.08.2019    8179    Jokemas    24    

Удобный просмотр результата запроса с большим количеством временных таблиц

Практика программирования v8 Абонемент ($m)

Если Вам часто приходится просматривать в отладчике сложные пакетные запросы с большим количеством временных таблиц, то эта статья для Вас.

1 стартмани

27.08.2019    10527    ids79    21    

Обмен большими данными между клиентом и сервером

Внешние источники данных v8 Абонемент ($m)

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

1 стартмани

27.08.2019    13023    logos    24    

БСП: Дополнительная обработка (Регламенты), примеры от простого к сложному Промо

Практика программирования БСП (Библиотека стандартных подсистем) v8 1cv8.cf Абонемент ($m)

Очень много попадается странных решений, которые можно решить через БСП:Дополнительные отчеты и обработки. Я бы вообще БСП из-за этой подсистемы переименовал в «Большое Спасибо Программистам». Поработаем с подсистемой в части написания регламентных заданий.

1 стартмани

10.05.2018    43128    dsdred    36    

Запуск фонового задания во внешней обработке. Отключение предупреждений защиты от опасных действий в фоновом задании

Практика программирования v8 1cv8.cf Абонемент ($m)

Как запустить фоновое задание из модуля внешней обработки используя БСП. Как отключить безопасный режим и сообщения защиты от опасных действий независимо от профиля безопасности пользователя в фоновом задании во внешней обработке.

2 стартмани

24.08.2019    9693    BenGunn    22    

Изменяющееся контекстное меню в 1С 8.3

Практика программирования Работа с интерфейсом Разработка v8 v8::УФ Абонемент ($m)

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

1 стартмани

06.08.2019    14620    signum2009    16    

Использование HTTP-сервиса для создания "фронтенда" HTML/CSS/jQuery с кэшированием

WEB v8 1cv8.cf Абонемент ($m)

В статье описан способ создания "фронтенда" на HTML/CSS/jQuery и скрипт кеширования AJAX запросов на PHP.

1 стартмани

06.08.2019    13426    Sedaiko    24    

Некоторая работа с данными через COM Промо

Практика программирования v8 Абонемент ($m)

В статье приведены примеры работы с Платформой 8.X через COM (точнее, через объект COMConnector). Примеры кода были использованы при реализации прикладных задач в процессе трудовой деятельности.

2 стартмани

05.12.2012    56855    wowik    32    

Менеджер потоков: реализация "любой" задачи в потоках

Производительность и оптимизация (HighLoad) Инструментарий разработчика v8 Абонемент ($m)

Менеджер потоков – один их новых инструментов, который упрощает работу разработчиков. Насколько легко с ним, на конференции Infostart Event 2018 Education показал начальник отдела автоматизации 1С Иван Филимонов компании «Трансстроймеханизация».

01.08.2019    9182    DarkAn    6    

Процедура ПриКомпоновкеРезультата

Практика программирования v8 1cv8.cf Абонемент ($m)

Коллекция кода

1 стартмани

26.07.2019    34300    vasilev2015    63    

10 способов получить модуль числа (а может, и больше)

Практика программирования Разработка v8 1cv8.cf Абонемент ($m)

Пишем функцию вычисления модуля числа. Сколько способов существует? Давайте посчитаем!

1 стартмани

11.07.2019    7160    sam441    29    

Работа со схемой запроса Промо

Инструментарий разработчика Практика программирования v8 v8::Запросы Абонемент ($m)

Стандартом взаимодействия с реляционной базой данных стал язык SQL. Приемником SQL в 1С является язык запросов. Язык запросов, также как и SQL, является структурированным. Составляющие структуры запроса отвечают на разные вопросы о том, какие данные требуется получить и какие манипуляции с множествами данных необходимо произвести при получении. В простых случаях текст запроса можно написать вручную, однако в сложных случаях, а также при программном формировании, - лучше воспользоваться объектной моделью запроса и использовать объект "Схема запроса". В статье дается описание объектной модели и особенностей работы с ней, а также приводится решение, упрощающее взаимодействие с объектом "Схема запроса".

1 стартмани

24.04.2018    42362    kalyaka    34    

Ловец дедлоков СУБД

Производительность и оптимизация (HighLoad) Практика программирования Разработка v8 Россия Абонемент ($m)

Анализ простейшего дедлока СУБД в рабочей базе с использованием ЦУП (центра управления производительностью) и profiler MS SQL (Microsoft SQL Server). Эта статья будет полезна людям, изучающим вопросы оптимизации работы 1С, или тем, у кого возникают дедлоки в рабочей базе. UPD 09.07.2019 добавлено воспроизведение блокировки в случае установки управляемой блокировки перед чтением набора записей регистра сведений. UPD 10.07.2019 добавлена тестовая база с примером.

1 стартмани

08.07.2019    10674    azazana    79    

Мониторинг производительности и искусственный интеллект

Производительность и оптимизация (HighLoad) Практика программирования Разработка v8 Абонемент ($m)

Расскажем и покажем практически, как использовать искусственный интеллект на страже мониторинга производительности. У вас появится возможность создать собственного помощника Ларису, которая возьмет на себя вопросы по контролю и диагностике состояния обслуживаемой системы.

1 стартмани

01.07.2019    8937    ivanov660    28    

"Убер на складе": динамический расчет маршрутов с учетом реальных расстояний

Учет ТМЦ Практика программирования Учет ТМЦ v8 УУ Абонемент ($m)

Представляю методику и инструмент для динамического расчета маршрутов отбора на высоконагруженных складах для максимального повышения эффективности склада, ускорения проходимости и, как следствие, экономии денег. Это методика и обработка для интеграции в WMS решения. Тестировалось на 1С 8.3.14.1565.

3 стартмани

24.06.2019    14080    informa1555    17    

Многопоточность. Универсальный «Менеджер потоков» (фреймворк) с отслеживанием зависимости объектов Промо

Практика программирования Математика и алгоритмы Универсальные функции Производительность и оптимизация (HighLoad) v8 1cv8.cf Россия Абонемент ($m)

Восстановление партий, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

26.05.2017    48435    DarkAn    86    

1С:Ассемблер. Немного летнего веселья!

Практика программирования Разработка v8 1cv8.cf Абонемент ($m)

Все вы, наверное, слышали, что 1С-ники жалуются на свою систему, считая язык 1С недостаточно низкоуровневым, скучным и т.п. Все они с тоской поглядывают в сторону "настоящих" языков программирования. Так вот, господа, они неправы. В системе 1С есть места, где можно размять программерский мозг и получить удовольствие от низкоуровневой техники. Предлагаю вам погрузиться в недра виртуальной машины 1С и понять, как она работает. Там есть свой "ассемблер" и мы попробуем его в действии!

1 стартмани

21.06.2019    27522    Evil Beaver    119    

Простые примеры сложных отчетов на СКД

Практика программирования v8 v8::СКД 1cv8.cf Абонемент ($m)

Подписи в отчете. Особенности соединения наборов: как соединить несоединяемое. Остатки на дату и обороты по месяцам в одном отчете. Курс валюты на каждую дату без группировок и соединений в запросе. Отчет с произвольными колонками и с произвольной последовательностью. "Неадекватный отчет".

1 стартмани

12.06.2019    28242    Hatson    22    

Работа с графической схемой в объектной модели DOM

Универсальные функции v8 v8::УФ Абонемент ($m)

Пример кода для работы с графической схемой в объектной модели DOM, платформа 8.3.12.

1 стартмани

04.06.2019    7849    botokash    19    

Агрегатное суммирование строк в запросе – сложно, но не невозможно Промо

Математика и алгоритмы v8 Абонемент ($m)

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

1 стартмани

09.09.2013    77047    ildarovich    53    

XDTO для чайников

Обмен через XML v8 1cv8.cf Абонемент ($m)

Пример использования XDTO пакетов для выгрузки документа с табличной частью.

1 стартмани

29.05.2019    25819    HAMMER_59    39    

Отладка правил обмена КД2 для подсистемы БСП Обмен данными

Перенос данных из 1C8 в 1C8 v8 1cv8.cf Абонемент ($m)

Уже давно нельзя отлаживать правила обмена при помощи внешних файлов. Попробуем исправить это.

1 стартмани

27.05.2019    11818    fenixnow    5    

Создание внешней печатной формы в формате документа Word

Практика программирования Разработка v8 1cv8.cf Абонемент ($m)

В статье написано, как создать внешнюю печатную форму (для конфигураций с БСП) в формате Word.

1 стартмани

17.05.2019    11678    ВикторП    20    

Новый запрос и новая таблица значений как функции Промо

Практика программирования v8 Абонемент ($m)

Предлагается две простые функции, использование которых уменьшает объем кода в конфигурациях на платформе «1С:Предприятие 8». Эти функции можно добавлять к своему общему модулю, что сделает процесс программирования более эффективным.

1 стартмани

27.11.2012    44882    ildarovich    46    

Программное формирование картинки в 1С:Предприятие 8.3.9 (ПотокВПамяти / ЗаписьДанных)

Универсальные функции v8 1cv8.cf Абонемент ($m)

В статье представлен код программного формирования картинки (двоичные данные) без всяких внешних компонент, без формирования строки Base64, используя лишь встроенные механизмы 1С предприятие 8.3.9 (объекты ПотокВПамяти и ЗаписьДанных). Сам по себе код формирования картинки не несёт ничего нового. Всё описано в википедии. Захотелось попробовать новые методы, но никак не доходитили руки. В приложении обработка практически с этим же кодом.

1 стартмани

16.05.2019    8825    yku    7    

Ops средствами 1С:Предприятие

Практика программирования Разработка v8 1cv8.cf Абонемент ($m)

В статье описан программный пакет "Автоматизация ИТ-процессов" (АИТП), позволяющий автоматизировать задачи по администрированию, управлению и обслуживанию ИТ-инфраструктуры.

1 стартмани

23.04.2019    17027    blackhole321    28    

1C + Python + Django Rest Framework + Vue.js. Опыт несложной full-stack разработки

Практика программирования Внешние источники данных Обмен через XML WEB Разработка v8 1cv8.cf Абонемент ($m)

В этой статье мы рассмотрим путь и основные моменты создания небольшого вэб-сервиса, который мы называем "Онлайн Прайс-лист". Выгрузка из 1С, бэкенд, фронтенд, получение заказов в 1С.

1 стартмани

22.04.2019    31248    riposte    63    

Перенос данных с использованием XDTO

Обмен через XML v8 Россия Абонемент ($m)

Использование объекта типа "ОбъектXDTO" для переноса данных из одной конфигурации в другую

1 стартмани

21.04.2019    10298    axae    10