12.01.2021 Максим Федоров 18731
Структура данных в виде дерева

Содержание:

  1. Подготовка "дерева" через формирование запроса базы данных.
  2. Подготовка "дерева" через СКД в 1С.

 

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

 

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

 

Для примера возьмем документ "Рейс" в конфигурации "ТМС логистика". В документе на закладке "Маршрут" выводиться информация о виде операции (погрузка, выгрузка) и адрес.


Пример документа ТМС логистика

Пример документа «ТМС логистика»


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

 

В этой статье будут рассмотрены только варианты заполнения "ДереваЗначений", с одним уровнем вложенности. Обработка выбора, добавления и удаления строк и сохранения – это тема, достойная отдельной статьи, но, по сути, там нет такой вариативности, какую обеспечивает заполнение "ДереваЗначений".  

 

1. Подготовка "дерева" через формирование запроса базы данных.


Данный метод подходит, если необходимо сделать группировку только по одному полю. Например, если нам необходимо сгруппировать данные только по полю "Операция".

 

Формируем запрос:

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

                               Запрос.УстановитьПараметр("ТЗМаршрут",объект.Маршрут.Выгрузить());

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

                               "ВЫБРАТЬ

                               |              упРейсМаршрут.НомерСтроки КАК НомерСтроки,

                               |              упРейсМаршрут.ЗаданиеНаПеревозкуГруза КАК ЗаданиеНаПеревозкуГруза,

                               |              упРейсМаршрут.Операция КАК Операция,

                               |              упРейсМаршрут.Адрес КАК Адрес,

                               |              упРейсМаршрут.НомерЗвена КАК НомерЗвена

                               |ПОМЕСТИТЬ ВТМаршрут

                               |ИЗ

                               |              &ТЗМаршрут КАК упРейсМаршрут

                               |;

                               |

                               |////////////////////////////////////////////////////////////////////////////////

                               |ВЫБРАТЬ

                               |              ВТМаршрут.НомерСтроки КАК НомерСтрокиТЧ,

                               |              ВТМаршрут.ЗаданиеНаПеревозкуГруза КАК ЗаданиеНаПеревозкуГруза,

                               |              ВТМаршрут.Операция КАК Операция,

                               |              ВТМаршрут.Адрес КАК Адрес,

                               |              ВТМаршрут.НомерЗвена КАК НомерЗвена

                               |ИЗ

                               |              ВТМаршрут КАК ВТМаршрут

                               |ИТОГИ ПО

                               |              Операция";

               

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

               

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

    ЗначениеВРеквизитФормы(ПромежуточноеДерево,"ДеревоМаршрутов");

 

В результате формирования запроса базы данных получаем дерево типов данных вида:


документ ТМС логистика в 1С

Дерево типов данных  

 

2.       Подготовка "дерева" через СКД в 1С


Данный метод подходит, если надо сделать группировку по нескольким полям. Например, нам необходимо сгруппировать данные по полям "Операция" и "Адрес".

 

Создаем схему компоновки данных, где на закладке "Настройка" указываем группировку по нескольким полям. В данном примере 2 поля:


Схема компоновки данных

Схема компоновки данных


Затем пишем вызов СКД в 1С:

 

                //получаем схему СКД

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

                НовыйСКД = ТекОбъект.ПолучитьМакет("МакетСКДМаршрут");

                //инициализируем настройки СКД     

                Настройки = НовыйСКД.НастройкиПоУмолчанию;

                ДанныеРасшифровкиСКД = Новый ДанныеРасшифровкиКомпоновкиДанных;

                КомпоновщикМакета = Новый КомпоновщикМакетаКомпоновкиДанных;

                ПроцессорКомпоновкиДанных = Новый ПроцессорКомпоновкиДанных;

                МакетКомпоновки = КомпоновщикМакета.Выполнить(НовыйСКД,Настройки,

                ДанныеРасшифровкиСКД,,Тип("ГенераторМакетаКомпоновкиДанныхДляКоллекцииЗначений"));

                //передаем данные в СКД

                ВнешниеДанные = Новый Структура("Маршруты",Объект.Маршрут.Выгрузить());

                ПроцессорКомпоновкиДанных.Инициализировать(МакетКомпоновки,ВнешниеДанные,ДанныеРасшифровкиСКД);

                //подготавливаем данные для получения из СКД

                ПромежуточноеДерево = Новый ДеревоЗначений;

                ПроцессорВывода = Новый ПроцессорВыводаРезультатаКомпоновкиДанныхВКоллекциюЗначений;

                ПроцессорВывода.УстановитьОбъект(ПромежуточноеДерево);

                ПроцессорВывода.Вывести(ПроцессорКомпоновкиДанных);              

                //передаем полученное дерево на форму

                ЗначениеВРеквизитФормы(ПромежуточноеДерево, "ДеревоМаршрутов");

 

В результате выполнения мы получаем базу данных в виде дерева, группируемого по двум полям:


Таблица в виде дерева

Таблица в виде дерева

 

Специалист компании «Кодерлайн»

Максим Федоров

 

Наши проекты

ООО «Аэроэкспресс»
ООО «Аэроэкспресс»

Отрасль:

Внедренное типовое решение:
1С:ERP. Управление холдингом

· Планирование закупок · Управление закупочными процедурами, включая 223 ФЗ ...

Госкорпорация «Ростех»
Госкорпорация «Ростех»

Отрасль:
Производство, ТЭК >> Машиностроение, приборостроение

Внедренное типовое решение:
1С:Управление холдингом 1.3.

Специалисты «Кодерлайн» помогли разработать и внедрить автоматизированную...

Автоматизация производственного планирования нефтесервисной компании на базе 1С:ЕРП 2.0
ЗАО «Инвестгеосервис»

Отрасль:
Нефтесервис

Внедренное типовое решение:
1С:ERP Управление предприятием 2.0

- Блок планирования проектов (процессы объемно-календарного планирования пр...

ООО «ДАФ Тракс Рус» (DAF Trucks Rus)
ООО «ДАФ Тракс Рус» (DAF Trucks Rus)

Отрасль:
Машиностроение

Внедренное типовое решение:
«1С:Управление корпоративными финансами»

- Осуществлена разработка матрицы прав и ролей для финансового подразделени...

Фирма 1С
Фирма 1С

Отрасль:

Внедренное типовое решение:
1С:Документооборот

- Подготовка функциональной модели прикладного решения «1С:Документооборот...

ООО «Лаборатория успеха»
ООО «Лаборатория успеха»

Отрасль:
Общественное и плановое питание, гостиничный бизнес, туризм

Внедренное типовое решение:
1С:Зарплата и управление персоналом 8. КОРП

Кадровый учет;
Расчет зарплаты;...

ОАО «Интер РАО – Электрогенерация»
ОАО «Интер РАО – Электрогенерация»

Отрасль:
Электрогенерация

Внедренное типовое решение:
1С:Управление производственным предприятием

Для работы 2500 пользователей в 9 часовых поясах организована территориально-...

Внедрение ПП «1С:Предприятие 8. Аренда и управление недвижимостью на базе "1С:Бухгалтерия 8"» в компании «Бутово Молл»
ООО «Бутово Молл»

Отрасль:
Недвижимость

Внедренное типовое решение:
1С:Аренда и управление недвижимостью на базе «1С:Бухгалтерия 8»

Управление продажами, логистикой и транспортом (SFM, WMS, TMS):
- Оформление зак...

Доработка конфигурации Заказчика «1С:Управление строительной организацией»
ЗАО «Стройтрансгаз»

Отрасль:
Проектирование

Внедренное типовое решение:
1С:Управление строительной организацией

Взаиморасчеты с поставщиками;
- Оформление заказов поставщикам;
- Склад ...

Разработка функциональных требований к информсистеме на базе «1С:Управление холдингом 8»
ФГУП «СВЯЗЬ-безопасность»

Отрасль:
Охранные услуги

Внедренное типовое решение:
1С:Управление холдингом

- Зафиксировали процессы по блокам бухгалтерского, налогового учета, казнач...

ПЭК
ПЭК

Отрасль:
Грузоперевозки

Внедренное типовое решение:
«1С: Управление торговлей»

- Создание прототипа SRM-системы на базе «1С: Управление торговлей»
- Автомат...

АО «Вертолетная сервисная компания»
АО «Вертолетная сервисная компания»

Отрасль:
МТО эксплуатации вертолетной техники

Внедренное типовое решение:
1С:Бухгалтерия КОРП

- Консультации по сложным вопросам налогового и бухгалтерского учета;
- Ра...

Наши соц. сети

Telegram-канал «Koderline 1С» Группа в Вконтакте «Кодерлайн КОРП» Rutube

Остались вопросы - обратитесь к нам!

Впишите свои Имя и Телефон, чтобы мы ответили на все интересующие Вас вопросы.
ФИО*
E-mail*
Телефон*
Сообщение