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

Содержание:

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

 

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

 

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

 

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


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

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


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

 

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

 

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


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

 

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

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

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

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

                               "ВЫБРАТЬ

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

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

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

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

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

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

                               |ИЗ

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

                               |;

                               |

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

                               |ВЫБРАТЬ

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

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

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

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

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

                               |ИЗ

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

                               |ИТОГИ ПО

                               |              Операция";

               

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

               

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

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

 

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


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

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

 

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


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

 

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


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

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


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

 

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

 

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


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

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

 

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

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

 

Наши проекты

1с-РАРУС МСК
1с-РАРУС МСК

Отрасль:
Разработка компьютерного программного обеспечения

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

- Финансово-бухгалтерский блок
- Казначейство ...

Автоматизация учета на базе ПП "1С:Комплексная автоматизация 8" в ЗАО "Крюгер-Гранд"
ЗАО «Крюгер-Гранд»

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

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

- Создание интерфейсов и наборов прав пользователей;
- Отражению временных ...

ООО «ТейблТок»
ООО «ТейблТок»

Отрасль:
Общественное питание и рестораны

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

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

ООО “РТИТС”
ООО “РТИТС”

Отрасль:
Транспортные системы

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

Блок регламентированного кадрового учета и расчета заработной платы в 1С:ERP;...

ООО "РУКАРД-АУРА"
ООО "РУКАРД-АУРА"

Отрасль:
Профессиональные услуги

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

- Налоговый учет;...

ООО "АСТАРМЕДИКА КЛИНИКА МИКРОХИРУРГИИ ГЛАЗА"
ООО "АСТАРМЕДИКА КЛИНИКА МИКРОХИРУРГИИ ГЛАЗА"

Отрасль:
Деятельность больничных организаций

Внедренное типовое решение:
БИТ:Управление медицинским центром 8

- Управление отношениями с клиентами (CRM)
- Делопроизводство
- Ведение но...

ООО "Смена"
ООО "Смена"

Отрасль:
Торговля, склад, логистика, транспорт

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

Банк и касса
Расчеты с контрагентами
Торговые операции
Взаиморасчеты с...

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

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

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

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

Внедрение 1С:Управление торговлей в оптово-розничной компании «Ална-Байк»
ИП Титов Виктор Сергеевич «Ална-Байк»

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

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

- Управление складами;
- Управление заказами поставщиков;
- Управление зак...

ООО «Солви Пак»
ООО «Солви Пак»

Отрасль:
Торговля. Производство печати на рулонных материалах

Внедренное типовое решение:
1С:CRM+1С:Комплексная автоматизация

Управление отношениями с клиентами (CRM) ...

ФГОУ ВПО «Горский государственный аграрный университет»
ФГОУ ВПО «Горский государственный аграрный университет»

Отрасль:
Образование

Внедренное типовое решение:
1С:Колледж ПРОФ

- Управление персоналом и кадровый учет (HRM):
Кадровый учет
Управление об...

ООО "ЛИКАРД" (Лукойл)
ООО "ЛИКАРД" (Лукойл)

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

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

Делопроизводство
• Учет и контроль исполнения поручений
Учет и хранение...

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

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

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

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