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

Содержание:

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

 

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

 

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

 

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


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

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


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

 

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

 

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


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

 

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

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

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

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

                               "ВЫБРАТЬ

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

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

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

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

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

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

                               |ИЗ

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

                               |;

                               |

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

                               |ВЫБРАТЬ

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

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

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

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

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

                               |ИЗ

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

                               |ИТОГИ ПО

                               |              Операция";

               

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

               

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

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

 

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


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

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

 

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


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

 

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


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

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


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

 

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

 

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


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

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

 

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

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

 

Наши проекты

Оптимизация производительности системы
ЗАО ИД «Комсомольская правда»

Отрасль:
Медиа

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

- Оптимизация производительности системы, в том числе сервера Postgre. ...

Внедрение «1С:Зарплата и управление персоналом 8 КОРП» в компании «ПБК»
ООО «Партнер Бухгалтер Консультант»

Отрасль:
Бухгалтерские услуги

Внедренное типовое решение:
1С:Зарплата и управление персоналом

- Интеграция продукта с базой данных оперативного учета Axapta;
- Доработка фу...

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

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

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

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

Автоматизация интеграции с информсистемами клиентов на базе «1С:Предприятие 8. WMS Логистика. Управление складом»
ОАО «Фрейт Линк»

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

Внедренное типовое решение:
«1С:Предприятие 8. WMS Логистика. Управление складом»

– Управление складскими запасами;
– Оформление заказов покупателей;
– ...

Внедрение блока расчета себестоимости РАУЗ в 1С:УПП 8
ООО «Пелигрин Матен»

Отрасль:
Производство

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

– Оформление заказов покупателей;
– Взаиморасчеты с покупателями;
– О...

ООО "АСК ИНЖИНИРИНГ"
ООО "АСК ИНЖИНИРИНГ"

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

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

Делопроизводство
Учет и хранение документов
Ведение номенклатуры дел
...

АО «РЭП Холдинг»
АО «РЭП Холдинг»

Отрасль:
Энергомашиностроительный холдинг

Внедренное типовое решение:
«1С: Управление производственным предприятием» и «1С:Консолидация ПРОФ»

- Функциональный блок «Консолидированная отчетность РСБУ» - разработка час...

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

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

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

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

Автоматизация контроля исполнительской дисциплины на базе ПП «1С:Документооборот 8 ПРОФ»
ООО «ФСК Лидер»

Отрасль:
Строительство и девелопмент

Внедренное типовое решение:
1С:Документооборот 8 ПРОФ

- Делопроизводство;
- Учет и хранение документов;
- Учет и контроль исполне...

ЗАО «Инвестгеосервис»
ЗАО «Инвестгеосервис»

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

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

Объемно-календарное планирование производства Автоматизация бизнес-проце...

Автоматизация кадрового учета на базе «1С:ERP Управление предприятием 2.0»
Автопредприятие ПАО «Газпром»

Отрасль:
Транспорт

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

- Настройка подсистемы кадрового учета;
- Перенос персональных данных;
- З...

ООО ХДМ Рус
ООО ХДМ Рус

Отрасль:
Торговля

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

Бухгалтерский учет Банк и касса Расчеты с контрагентами Торговые операции ...

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

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

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

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