Горизонтальное представление данных 1С

19.02.25

Разработка - Работа с интерфейсом

Делаем иерархические отчеты в 1С удобными: как визуализировать сложные структуры.

Скачать файл

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

Наименование По подписке [?] Купить один файл
Горизонтальное представление данных 1С
.epf 8,75Kb
0
0 Скачать (1 SM) Купить за 1 850 руб.

Допустим, перед нами стоит задача получить сумму начислений по подразделениям, при этом важно учесть иерархию этих подразделений. Мы можем реализовать это, написав небольшой запрос.

ВЫБРАТЬ
НачислениеЗарплатыНачисления.Подразделение КАК Подразделение,
СУММА(НачислениеЗарплатыНачисления.Результат) КАК Результат
ИЗ
Документ.НачислениеЗарплаты.Начисления КАК НачислениеЗарплатыНачисления
ГДЕ
НачислениеЗарплатыНачисления.Ссылка.МесяцНачисления = &МесяцНачисления
СГРУППИРОВАТЬ ПО
НачислениеЗарплатыНачисления.Подразделение
УПОРЯДОЧИТЬ ПО
Подразделение
ИТОГИ
СУММА(Результат)
ПО
Подразделение ТОЛЬКО ИЕРАРХИЯ

 

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



А теперь представьте: вы сформировали отчет по начислениям зарплаты для компании с разветвленной структурой подразделений. Данные выводятся в виде классического «дерева» — это работает, если уровней 2–3. Но когда подразделений десятки, а иерархия напоминает матрешку (например, «Головной офис → Финансы → Бухгалтерия → Отдел расчетов → Группа первички»), отчет превращается в бесконечную вертикальную прокрутку. Такое дерево значений визуально оценить сложно. При 3+ уровнях навигация усложняется — пользователь теряет контекст.



А если представить, что дерево значений с большим количеством уровней можно отобразить горизонтально ?


 

Уверен, что в таком виде дерево значений визуально оценить куда проще.

Эта обработка — наглядный пример того, как с помощью программного кода данные преобразуются в удобную горизонтальную таблицу. Вот что делает её особенной:

  • Количество уровней определяется динамически — система сама подстраивается под структуру ваших данных. Никаких ручных расчетов!
  • Хотите изменить логику или добавить новые параметры? Всё, что вам нужно — отредактировать запрос. Никаких сложных доработок!
  • Код написан максимально прозрачно, чтобы вы могли легко разобраться в его работе или адаптировать под свои задачи.

Тестирование проводилось на платформе 1С:Предприятие 8.3 (8.3.26.1521).

Проверено на следующих конфигурациях и релизах: Зарплата и управление персоналом КОРП, редакция 3.1 (3.1.29.78). 

С программным кодом можно ознакомиться на Git Hub: horizontal-view-of-data

горизонтальная иерархия

См. также

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

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

5000 руб.

14.01.2016    55610    17    23    

43

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

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

2400 руб.

29.06.2020    19926    28    6    

44

Работа с интерфейсом Программист Стажер Платформа 1С v8.3 Бесплатно (free)

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

20.08.2024    23381    mrXoxot    44    

130

Работа с интерфейсом Программист Платформа 1С v8.3 Бесплатно (free)

Пример простого и симпатичного прогресс-бара в динамическом списке, без картинок, используя редактирование запроса.

27.05.2024    11924    smielka    37    

105

Работа с интерфейсом Платформа 1С v8.3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 Бесплатно (free)

Добавьте новогоднего настроения! Расширение создает декорацию в виде гирлянды на некоторых формах объектов.

27.12.2023    18332    1228    elcoan    53    

125

Инструментарий разработчика Работа с интерфейсом Программист Платформа 1С v8.3 1C:Бухгалтерия Абонемент ($m)

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

3 стартмани

10.04.2023    12867    167    acces969    31    

126

Работа с интерфейсом Программист Платформа 1С v8.3 1C:Бухгалтерия Абонемент ($m)

"MVC плохо применима в 1С" - познакомьтесь с моделью состояния и, возможно, ваше мнение поменяется! Представленное решение является эволюционным развитием идеи реализации MVC для 1С. В новой версии добавлены DSL для описания модели состояния, а также параметризация свойств параметров и элементов формы.

1 стартмани

05.07.2022    7929    kalyaka    6    

33

Работа с интерфейсом Программист Пользователь Платформа 1С v8.3 8.3.14 1C:Бухгалтерия 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Абонемент ($m)

Ещё с времен платформы 8.3.13 можно изменять цвет стилей интерфейса главного окна. Данное расширение позволит вам выбрать из подготовленных десятка стилей на свой вкус.

1 стартмани

01.07.2022    26835    423    rpgshnik    69    

101
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. VmvLer 19.02.25 15:14 Сейчас в теме
Если эту идеи оформить как модификацию запросов механизма представлений.
Например, в расширении модуля объекта объявить доработку метода:

ИнициализироватьОтчетПосле(ЭтотОбъект)

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

Пока это разовый костыль, который нужно рутинно тиражировать в каждом отчете.

При всем уважении.
2. iclect 32 19.02.25 16:38 Сейчас в теме
(1) Изначально задача заключалась в исследовании возможности горизонтального отображения иерархии в отчетах. К сожалению, на тот момент мне не удалось найти оптимальное решение средствами СКД, поэтому в качестве временного варианта я реализовал его через внешнюю обработку — ею и решил поделиться.

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

В ближайших планах:

1. Доработать логику вывода горизонтальной иерархии в рамках СКД.
2. Интегрировать её в механизм инициализации отчетов через расширения (например, через модификацию метода ИнициализироватьОтчетПосле), как вы предложили.
3. ixijixi 1987 19.02.25 17:21 Сейчас в теме
Как по мне, вертикальная иерархия гораздо более читабельна, нежели горизонтальная. ИМХО, естественно)
4. VmvLer 19.02.25 17:25 Сейчас в теме
(3) руководство часто любит горизонталку на совещаниях на большом экране)
спрос есть
Оставьте свое сообщение