Полезные примеры составления схемы компоновки данных #2

31.03.21

Разработка - СКД

Еще один набор примеров как решить частные задачи в СКД

Скачать файлы

Наименование Файл Версия Размер
Три схемы
.zip 5,01Kb
15
.zip 5,01Kb 15 Скачать

Первая часть

Оглавление

  1. Вывод группы похожих строк с отображением названия только в первой строке
  2. Убрать заголовок ресурса из шапки СКД
  3. Убрать дубли в иерархии элементов

Вывод группы похожих строк с отображением названия только в первой строке

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

Изначально мы имеем детальные записи, отображающие информацию во всех строках

Нужно получить следующий вид:

Это достигается созданием вычисляемого поля:

ВычислитьВыражение("Количество(Различные ШифрИВЦ)",,,"Предыдущая", "Текущая") = 2 ИЛИ ВычислитьВыражение("Количество(ШифрИВЦ)",,,"Предыдущая", "Предыдущая") Есть null 

Как это работает? Для каждой детальной записи выполняется проверка ключевого с предыдущей записью на "одинаковость", но поскольку для первой строки детальных записей это не будет работать, добавлена дополнительная проверка на отсутствие предыдущей записи.

И последующему применению условного оформления требуемых полей по условию этого поля

В итоге:

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

Убрать заголовок ресурса из шапки СКД

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

Данную задачу можно решить, добавив Макет группировки (тип макета Заголовок) поля вертикальной группировки (в данном примере поле вертикальной группировки Вид).

Результат:

"Правильная" иерархия элементов

Как убрать дубли при выводе элементов справочника иерархия элементов.

Если у справочника используется иерархия элементов, то при выводе ее в СКД будет наблюдаться повторение родителей на уровне элементов, пример:

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

Добавляем пользовательское поле Родитель, в котором вычислен родитель поля. В выражении детальных записей пользовательского поля пишем ВычислитьВыражение("Подразделение", "", "Иерархия"), в выражении итоговых записей - пишем то же самое.

Далее, создаем отбор для группировки с иерархией(именно для группировки, а не для всего отчета). 

Добавляем группу ИЛИ, в эту группу добавляем два элемента: Подразделение Не равно ПользовательскоеПоле, Уровень в группе = 1

Важно! Для группы ИЛИ устанавливаем использование После группировки или для иерархии 

В итоге получаем нормальную иерархию:

Схемы-примеры, которые будет работать в конфигурации на базе УПП 1.3 и потомков - приложены

См. также

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

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

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравнение объектов, Все функции, Подписки на события и др. Редактор запросов и кода с раскраской и контекстной подсказкой. Доработанный конструктор запросов тонкого клиента. Продукт хорошо оптимизирован и обладает самым широким функционалом среди всех инструментов, представленных на рынке.

12000 руб.

02.09.2020    101555    563    385    

608

1C:Предприятие для программистов: Запросы и отчеты. Онлайн-интенсив с 27 ноября по 27 декабря 2023г.

1С-программирование Запросы СКД Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Данный онлайн-курс предусматривает углубленное изучение языка запросов и возможностей системы компоновки данных, которые понадобятся при разработке отчетов, работающих на платформе “1С:Предприятие” в рамках различных прикладных решений. Курс предназначен для тех, кто уже имеет определенные навыки конфигурирования и программирования в системе “1С:Предприятие”, а также для опытных пользователей различных прикладных решений, которые используют в своей работе отчеты разного назначения. Курс является вторым курсом траектории развития 1С-Разработчика, с углубленным изучением тем "Язык запросов" и "Отчеты", которые были рассмотрены в рамках “Базового курса для начинающих 1С-программистов”.

7500 руб.

04.10.2023    2560    48    0    

47

Модель СКД

Инструментарий разработчика СКД Платформа 1С v8.3 Система компоновки данных Абонемент ($m)

DSL для работы с СКД.

1 стартмани

15.11.2023    3980    10    kalyaka    4    

81

Разрыв страницы в СКД. Легко!

СКД Платформа 1С v8.3 Система компоновки данных Бесплатно (free)

Когда отчет надо разделить по страницам, это всегда проблема для разработчика. Поскольку в СКД нет стандартных вариантов, как это сделать. Нашел (на свой взгляд) самое простое и оптимальное решение.

01.09.2023    3190    KVIKS    15    

76

Гибкие отборы через СКД на управляемых формах. Демо-обработка

СКД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Абонемент ($m)

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

2 стартмани

07.06.2023    4596    26    quazare    7    

46

Вывод элементов иерархии верхнего уровня на СКД

СКД Платформа 1С v8.3 Абонемент ($m)

Как получить родителя первого уровня иерархического справочника с помощью СКД.

1 стартмани

06.06.2023    4221    echo77    6    

72

Обработка результатов запроса произвольными вычисляемыми полями. Обзор некоторых новых функций СКД

Запросы СКД Платформа 1С v8.3 Запросы Система компоновки данных Конфигурации 1cv8 Бесплатно (free)

В данной статье вспомним, как обрабатывать результаты запроса в вычисляемых полях СКД, а также сделаем небольшой обзор на новые функции СКД платформы 8.3.20.

07.02.2023    5508    quazare    7    

38
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. FesenkoA 57 22.05.18 14:18 Сейчас в теме
Что будет если, допустим, в вашем отчете отсортировать по "ЦКЛ"? И в чем принципиальное различие между этим и, собсно, группировкой?
не критикую, спрашиваю.
2. SITR-utyos 1415 22.05.18 14:28 Сейчас в теме
(1) Если отсортировать по не ключевому полю - то результат будет другой. Собственно задумка получить, отчет сортированный по ключевым полям.

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

По сути, данный пример - это эксклюзив для особенных заказчиков.
3. FesenkoA 57 22.05.18 15:22 Сейчас в теме
(2)Для Очень уж особенных)) Но использование интересное, спасибо!
10. пользователь 24.05.18 05:43
Сообщение было скрыто модератором.
...
4. shtinalex 260 22.05.18 19:00 Сейчас в теме
Телега не моя, но вот еще вариант с мисты:
Результат объединения строк колонки "Поставщик"

Вычисляемые поля:

Условное оформление:

Ресурсы:


Схема СКД прилагается:
Прикрепленные файлы:
GruppyNeGruppy.xml
SagittariusA; vladimir-89; brenli; igee12; unichkin; rpgshnik; CnupT; dj_serega; PetrPan; romankoav; Irwin; Korolev; emakei; AlX0id; SITR-utyos; Serj1C; Shrayky2; +17 Ответить
5. Serj1C 483 23.05.18 07:06 Сейчас в теме
Я бы тоже делал вариант (4)
6. SITR-utyos 1415 23.05.18 08:26 Сейчас в теме
(4) Спасибо! Предложенная реализация более наглядна и понятна. Хочу обратить внимание, что из-за того что предыдущий контрагент вычисляется в ресурсах - данная реализация будет работать только для группировок
7. rmarkovych 25 23.05.18 14:26 Сейчас в теме
Спасибо Автору статьи!!! Очень помогло для моего отчета в 1С ДО. Получилось именно так, как и хотел Заказчик
Прикрепленные файлы:
8. Milanick 23.05.18 16:59 Сейчас в теме
Коллеги, может кто помочь с такой реализацией задачи как "Сравнение продаж по периодам", с использованием ВычислитьВыражение

Пример , как хочет видеть форму заказчик:
Прикрепленные файлы:
СравнениеПериодов.xml
9. Milanick 23.05.18 17:02 Сейчас в теме
Что-то я встрял, как получить значение из предыдущей группировки и сделать разницу между ними :(
11. SITR-utyos 1415 24.05.18 10:57 Сейчас в теме
(9) Держи, все просто. Судя по всему, ты ошибся в установке параметра КП2. Я в наборы данных ввел поле КоличетвоПериода1, КоличествоПериода2, чтобы их как-то различать.
И выражение ресурса упростил. Сделал все ТОЛЬКО для количества
Прикрепленные файлы:
СравнениеПериодов - работает.xml
12. Milanick 25.05.18 15:36 Сейчас в теме
(11) Спасибо большое.
13. Ibrogim 1302 12.07.18 09:11 Сейчас в теме
(0)
наблюдаться повторение родителей на на уровне

наблюдается повторение "на"
SITR-utyos; +1 Ответить
14. пользователь 24.11.18 10:41
Сообщение было скрыто модератором.
...
Оставьте свое сообщение