Конвертация данных. Небольшой тюнинг конфигурации

23.02.19

Разработка - Инструментарий разработчика

Мелкие исправления конфигурации КД2, которые облегчают жизнь

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
КД 2. Небольшой тюнинг конфигурации
.cf 55,94Kb
16 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Что доработано

  1. Изменена надпись в заголовке окна. В типовых решениях есть возможность указать заголовок программы. На этот заголовок удобно ориентироваться, когда у вас открыто несколько баз 1С;
  2. Отключено автоматическое создание ПКС для всех объектов, кроме перечислений. Это исключает ситуацию, когда случайно не сняв галку вы рекурсивно создаете ПКО для всей конфигурации;
  3. Исправлена ошибка из-за которой автоматически не проставляются ПКО в обработке Автонастройка правил конвертации свойств.

Изменение заголовка окна базы

В модуле обычного приложения делается вставка в процедуру ПриНачалеРаботыСистемы()

Процедура ПриНачалеРаботыСистемы()

	АвторизацияТекущегоПользователя();
	ВыполнитьОбновлениеИнформационнойБазы();
	
	ПервыйЗапуск = (Константы.НомерВерсииКонфигурации.Получить()="");
	
	// Открытие Панели функций
	ОткрытьПанельФункций = УправлениеПользователями.ПолучитьБулевоЗначениеПоУмолчанию(глТекущийПользователь, "ОткрыватьПриЗапускеПанельФункций", Истина);
	Если ОткрытьПанельФункций И (НЕ ПервыйЗапуск) Тогда
		Обработки.ПанельФункций.ПолучитьФорму().Открыть();
	КонецЕсли;
	
	// Открытие формы настройки правил регистрации
	ОткрытьПравилаРегистрации = УправлениеПользователями.ПолучитьБулевоЗначениеПоУмолчанию(глТекущийПользователь, "ОткрыватьПравилаРегистрации", Ложь);
	Если ОткрытьПравилаРегистрации Тогда
		ОткрытьПравилаРегистрации();
	КонецЕсли;
	
	// Открытие формы настройки правил обмена
	ОткрытьПравилаОбмена = УправлениеПользователями.ПолучитьБулевоЗначениеПоУмолчанию(глТекущийПользователь, "ОткрыватьПравилаОбмена", Ложь);
	Если ОткрытьПравилаОбмена Тогда
		ОткрытьПравилаОбмена();
	КонецЕсли;
	
	// Моя вставка, Крынецкий, 30.03.2016. Установим заголовок приложения, чтобы не путать его в командной панели Windows
	УстановитьЗаголовокПриложения(Метаданные.Синоним + "(" + Метаданные.Версия + ")");
	// Конец моей вставки
		
КонецПроцедуры // ПриНачалеРаботыСистемы()

Отключение автосоздания ПКС

Вставка в процедуре общего модуля ОбщегоНазначения:

Процедура РекурсивноеСозданиеПКО(Объект, ЗадаватьВопросПользователю = Истина, 
	СписокСозданныхПКО = Неопределено, ДляПодчиненныхОбъектовСоздаватьПКСТолькоДляПолейПоиска = Истина) Экспорт
	
	// если нет источника, то и создавать автоматически ничего не получится
	Если Объект.ЭтоГруппа 
		ИЛИ НЕ ЗначениеЗаполнено(Объект.Источник) Тогда
		
		Возврат;
		
	КонецЕсли;
	
	// Моя вставка, Крынецкий 2016-04-12. Отключим автоматическое создание правил конвертации свойств для всех, кроме перечислений
	Если Лев(Объект.ТипИсточника, 18) = "ПеречислениеСсылка" И
		 Лев(Объект.ТипПриемника, 18) = "ПеречислениеСсылка" Тогда
		 
		Если СписокСозданныхПКО = Неопределено Тогда
			СписокСозданныхПКО = Новый СписокЗначений;
		КонецЕсли;
		
		АвтоматическиСоздатьПКСПКЗПоПравилу(Объект, Истина, СписокСозданныхПКО, Ложь, ДляПодчиненныхОбъектовСоздаватьПКСТолькоДляПолейПоиска);
		СписокСозданныхПКО.Добавить(Объект.Ссылка);
		
		Возврат
	Иначе
		
		Возврат
		
	КонецЕсли;

	Если ЗадаватьВопросПользователю Тогда
		
		#Если Клиент Тогда
			// пользователю нужно задать вопрос о рекурсивном автоматическом создании ПКС, ПКЗ
			ОтветПользователя = Вопрос("Создать автоматически правила конвертации свойств, значений и подчиненных объектов?", 
			РежимДиалогаВопрос.ДаНет, , КодВозвратаДиалога.Да);
			
			Если ОтветПользователя <> КодВозвратаДиалога.Да Тогда
				
				Возврат;
				
			КонецЕсли;
		#КонецЕсли
		
	КонецЕсли;
	
	Если СписокСозданныхПКО = Неопределено Тогда
		СписокСозданныхПКО = Новый СписокЗначений;
	КонецЕсли;
	
	АвтоматическиСоздатьПКСПКЗПоПравилу(Объект, Истина, СписокСозданныхПКО, Ложь, ДляПодчиненныхОбъектовСоздаватьПКСТолькоДляПолейПоиска);
	СписокСозданныхПКО.Добавить(Объект.Ссылка);
		
КонецПроцедуры

Автоматически проставить ПКО в обработке Автонастройка правил конвертации свойств

Исправление формальных параметров в процедуре Обработка.АвтонастройкаПравилКонвертацииСвойств.МодульОбъекта

// Моя вставка Крынецкий 13.12.18. Поменяем местами формальные параметры
//Функция ОпределитьПоТипамНаличиеПКО(ТипПриемника, ТипИсточника) Экспорт
Функция ОпределитьПоТипамНаличиеПКО(ТипИсточника, ТипПриемника) Экспорт
// Конец моей вставки
	
	СтрокиТаблицы = мТаблицаНайденныхПКО.НайтиСтроки(Новый Структура("Источник, Приемник", ТипИсточника, ТипПриемника));
	
	Если СтрокиТаблицы.Количество() <> 0 Тогда 
		НайденноеПравилоКО = СтрокиТаблицы[0].СсылкаНаПКО;
	Иначе
		НайденноеПравилоКО = Неопределено;
	КонецЕсли;

	Возврат НайденноеПравилоКО;	
	
КонецФункции

Полезные инструменты для конвертации данных

Правила обмена — как на ладони!

Замена конфигурации в правилах переноса данных

Конвертация данных 2: удалить неиспользуемые ПКО

Все изменения тестировались на платформе 8.3.13.1513.

Вступайте в нашу телеграмм-группу Инфостарт

КД2 Конвертация данных

См. также

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта 1С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

15500 руб.

02.09.2020    213242    1165    413    

1050

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP, УНФ, КА и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку одновременно в несколько потоков. А так же автоматически, без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    40655    222    115    

212

Инструменты администратора БД Инструментарий разработчика Роли и права Программист 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

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

16000 руб.

10.11.2023    18831    76    39    

92

Пакетная печать Печатные формы Инструментарий разработчика Программист 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

Расширение для создания и редактирования печатных форм в системе 1С:Предприятие 8.3. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и прозрачность разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    26633    67    30    

96

Инструментарий разработчика Программист 1С v8.3 Платные (руб)

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

9500 руб.

17.05.2024    37697    134    55    

176

Инструментарий разработчика Нейросети Платные (руб)

Первые попытки разработки на 1С с использованием больших языковых моделей (LLM) могут разочаровать. LLMки сильно галлюцинируют, потому что не знают устройства конфигураций 1С, не знают нюансов синтаксиса. Но если дать им подсказки с помощью MCP, то результат получается кардинально лучше.<br/> Далее в публикации:<br/> MCP для поиска по метаданым 1С, справке синтакс-помошника и проверки синтаксиса.

9900 руб.

25.08.2025    4148    8    10    

15

Инструментарий разработчика 1С v8.3 1C:Бухгалтерия 1С:ERP Управление предприятием 2 Платные (руб)

Разработка Конструктор автоматизированных рабочих мест "Конструктор АРМ" реализована в виде расширения и является универсальным инструментом для создания АРМ любой сложности в пользовательском режиме.

3600 руб.

27.12.2024    3698    7    0    

12
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. acanta 18.12.18 14:46 Сейчас в теме
Добрый день.
Если Лев(Объект.ТипИсточника, 18) = "ПеречислениеСсылка" И
		 Лев(Объект.ТипИсточника, 18) = "ПеречислениеСсылка" Тогда


Здесь сравнивается тип источника и приемника с перечислением?
2. echo77 1928 18.12.18 14:57 Сейчас в теме
(1) Да, сравнивается строка, и да, похоже, что здесь ошибка. Поправлю. Спасибо
7. foxey 4 19.12.18 08:35 Сейчас в теме
(2) Что-то я не понял... Сказали, что поправите, а в тексте перед глазами те же две строки мутного содержания
Если Лев(Объект.ТипИсточника, 18) = "ПеречислениеСсылка" И
         Лев(Объект.ТипИсточника, 18) = "ПеречислениеСсылка" Тогда

Или Вы только в коде конфигурации в файле загрузки поправили? Надо бы и в тексте статьи тоже...
8. echo77 1928 19.12.18 08:48 Сейчас в теме
(7) Спасибо. Поправил и в тексте и в приложенном файле
3. acanta 18.12.18 14:58 Сейчас в теме
Можно еще план видов характеристик так же?
4. Поручик 4595 18.12.18 21:04 Сейчас в теме
Полезно. Надо втащить себе.
5. swimdog 782 19.12.18 00:27 Сейчас в теме
В полезных инструментах 1 и 3 ссылки одинаковые
6. echo77 1928 19.12.18 07:46 Сейчас в теме
Для отправки сообщения требуется регистрация/авторизация