Функции СКД: ВычислитьВыражение, ВычислитьВыражениеСГруппировкойМассив









Подробное описание и использование внутренних функций системы компоновки данных: Вычислить, ВычислитьВыражение, ВычислитьВыражениеСГруппировкойМассив, ВычислитьВыражениеСГруппировкойТаблицаЗначений.

Предыдущие статьи по СКД можно посмотреть по ссылкам ниже:

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

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

Применение внутренних функций достаточно широко, их можно использовать:

  • В реквизитах полей компоновки: «Выражение представления», «Выражение упорядочивания»  
  • В выражениях вычисляемых полей
  • В выражениях ресурсов
  • В выражениях связей наборов данных
  • В выражениях параметров
  • В выражениях параметров предопределенных макетов
  • В выражениях пользовательских полей

Самих функций очень много, полный их перечень можно посмотреть в справке 1С:

Внутренние функции СКД

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

Исключением являются функции из группы «Вычислить выражение»:

  • Вычислить
  • ВычислитьВыражение
  • ВычислитьВыражениеСГруппировкойМассив
  • ВычислитьВыражениеСГруппировкойТаблицаЗначений

Несмотря на достаточно внушительно описание в справке, их использование вызывает много вопросов. Функции часто используется «интуитивно», без глубокого понимания происходящего. 

Цель этой статьи — «осознанное» применение функций из группы «Вычислять выражение».

И так, поехали…

Первая функция «Вычислить» — на данный момент устарела. Она является подмножеством функции «ВычислитьВыражение», в которой реализован весь ее функционал и добавлены дополнительные возможности. Функция «Вычислить» осталась только для сохранения обратной совместимости. Поэтому перейдем сразу к рассмотрению функции «ВычислятьВыражение».

 

ВычислитьВыражение

Полный синтаксис функции следующий:

ВычислитьВыражение(Выражение, Группировка, ТипРасчета, Начало, Конец, Сортировка, ИерархическаяСортировка, ОбработкаОдинаковыхЗначенийПорядка)

Общее описание функции:

Выполнить произвольное выражение в контексте некоторой группировки или набора группировок. Можно провести аналогию с расчетом итогов. Отличие в том, что при расчете итогов, выражение рассчитывается всегда в контексте текущей группировки, в зависимости от уровня, на котором происходит расчет. Тогда как функция «ВычислитьВыражение» позволяет получить расчет в контексте произвольной группировки, отличной от текущей.

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

Рассмотрим эти параметры последовательно.

 

Группировка

Указание группировки, в контексте которой будет выполнен расчет.

Для примера, рассмотрим простой отчет со следующей структурой:

Структура простого отчета

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

ВычислитьВыражение("Сумма(Количество)", "Товар",)

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

Если создать поле с выражением:

ВычислитьВыражение("Сумма(Количество)", "Склад",)

Для всех записей (детальных и групповых) будет выполнен расчет по строкам, входящим в родительскую группировку «Склад»:

Расчет по группировкам

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

Например, следующие выражения указанное для расчета итога ресурсу «Количество» будут работать абсолютно одинаково:

ВычислитьВыражение("Сумма(Количество)", , )
Сумма(Количество)

Если в качестве параметра указано значение «ОбщийИтог», выражение будет рассчитано по всем строкам отчета.

 

Тип расчета

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

  • Группировка,
  • ОбщийИтог,
  • Иерархия,
  • ГруппировкаНеРесурса.

Если параметр не указан, значение по умолчанию — «Группировка». В этом случае никаких дополнительных уточнений выполняться не будет.

Если параметр имеет значение «ОбщийИтог», выражение будет вычисляться для всех группировок, которые находятся на одном уровне с указанной во втором параметре. Если во втором параметре группировка не указана, выражение будет вычислено для всех группировок или детальных записей, находящихся на одном уровне с текущей.

Ниже примеры работы выражений:

ВычислитьВыражение("Сумма(Количество)", "Товар", "ОбщийИтог")
ВычислитьВыражение("Сумма(Количество)", , "ОбщийИтог")

Тип расчета - общий итог

Значение параметра «Иерархия» имеет смысл только в том случае, если в отчете используется иерархическая группировка. Данная инструкция позволяет рассчитать выражение по родителю группировки, указанной во втором параметре. Если второй параметр не указан, по родителю текущей группировке.

Пример работы выражения:

ВычислитьВыражение("Сумма(Количество)", "Товар", "Иерархия")

Тип расчета - Иерархия

Если в отчете не используется иерархия для группировок, значение «Иерархия» работает аналогично значению «ОбщийИтог».

Существует еще загадочное значение «ГруппировкаНеРесурса».

Описание, приведенное в справке не понятно:

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

Мне не доводилось использовать данное значение. Проводя эксперименты, каких-то отличий применения данного значения от значения «Группировка», я не выявил. Очень может быть, что это значение не актуально на сегодняшний день.

Если кто-то использовал это значение, напишите, пожалуйста, в комментариях, очень интересно!

 

Группа параметров: «Начало», «Конец»

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

Поскольку данные параметры являются расширением параметра «Тип расчета», их нельзя использовать совместно с типами расчета: «ОбщийИтог», «Группировка».

Конструкции ниже являются аналогичными:

ВычислитьВыражение("Сумма(Количество)", , "ОбщийИтог")
ВычислитьВыражение("Сумма(Количество)", , , "Первая", "Последняя")

И

ВычислитьВыражение("Сумма(Количество)", , )
ВычислитьВыражение("Сумма(Количество)", , "Группировка")
ВычислитьВыражение("Сумма(Количество)", , , "Текущая", "Текущая")

Возможные значения параметров следующие:

  • Первая – первая группировка или детальная запись в наборе, возможно указать смещение «Первая(2)»,
  • Последняя — последняя группировка или детальная запись в наборе, возможно указать смещение «Последняя(2)»,
  • Предыдущая – предыдущая от текущей группировки или детальной записи в наборе, возможно указать смещение «Предыдущая(2)»,
  • Последующая — следующая от текущей группировки или детальной записи в наборе, возможно указать смещение «Следующая(2)»,
  • Текущая – текущая группировка или детальная запись,
  • ОграничивающееЗначение – ограничение по конкретному значению, которое можно указать в скобках. Ограничивающее значение применяется к первому полю упорядочивания.

Особенности применения параметров:

Конечная запись не должна предшествовать начальной.

Если указана только начальная запись, конечная будет равна значению «Текущая».

Если выражение рассчитывается по группировке, отбор записей выполняется на уровне этой группировки. Текущей в данном случае будет родительская группировка:

ВычислитьВыражение("Сумма(Сумма)", "Поставщик", ,"Предыдущая", "Текущая")

Диапазон группировок

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

ВычислитьВыражение("СУММА(Сумма)", "Поставщик", , "Первая", "Первая")

Диапазон для иерархической группировке

 

Параметр «Начало» можно использовать совместно с выражением, которое не является агрегатной функцией.

В этом случае, выражение будет вычислено для группировки или строки указанной в данном параметре. Ниже пример получения номера документа из предыдущей строки:

ВычислитьВыражение("Номер", , ,"Предыдущая") 

Если выражение (не агрегатная функция) получается не по строке, а по группировке, для расчета будет использоваться первая строка этой группировки:

ВычислитьВыражение("Номер", "Поставщик", ,"Предыдущая")

Номер предыдущего для группировки

 

Сортировка, ИерархическаяСортировка

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

Параметр «ИерархическаяСортировка» позволяет отдельно переопределить сортировку иерархии элементов. Если он не указан, для иерархии действует выражение параметра «Сортировка».

Если параметр «Сортировка» не указан, получение первой и последней записей будет выполняться с учетом текущей сортировки данных в отчете. 

В выражении сортировки можно использовать ключевые слова: «Возр», «Убыв», «Автоупорядочивание».

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

Пример выражения сортировки:

Поставщик Возр Автоупорядочивание

 

ОбработкаОдинаковыхЗначенийПорядка

Дополнительная настройка, которая на практике применяется крайне редко. Параметр имеет два значения: «Отдельно» (по умолчанию) и «Вместе».

Значение параметра «Отдельно» говорит о том, что записи с одинаковыми значениями упорядочивания будут выстроены в последовательность в любом случае. Последовательность будет определена согласно выводу данных в отчете.

Если значение параметра «Вместе», записи с одинаковыми значениями упорядочивания будут объединены. Например, при определении текущей записи, будут возвращены все строки со значением упорядочивания как у текущей. Предыдущая или последующая строки будут возвращены также с учетом объединения строк с одинаковым значением упорядочивания.   

 

Нюансы использования функции «ВычислитьВыражение»

Не стоит забывать, что функция «ВычислитьВыражение» совместно с агрегатной функцией, сама по себе уже является расчетом ресурса по некоторой группировке. По этому, если Вы указали для вычисляемого поля «Поле1» выражение следующего вида:

ВычислитьВыражение("Сумма(Количество)", "Товар",)

В выражении ресурса по этому полю не корректно использовать еще одну агрегатную функцию:

Сумма(Поле1)

В этом случае, по группировке «Товар», вы получите не корректные данные.

Правильным решением будет либо указание поля без агрегатной функции:

Поле1

Существует ограничение на использование полей содержащих функцию «ВычислитьВыражение» в групповых отборах.

Запрещается накладывать отбор на детальные записи, в которых используется функция «ВычислитьВыражение». Появляется ошибка вида «Выражение не может быть вычислено…». Если отбор накладывается на уровне группировки, и выполняется по полю «Ресурс» запрет распространяется только на конструкцию:  

ВычислитьВыражение("Сумма(Количество)", , "ОбщийИтог")

Для остальных выражений, например:

ВычислитьВыражение("Сумма(Количество)", , , "Первая", "Текущая")

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

ВычислитьВыражение("Сумма(Количество)")

Скорее всего отбор будет не тем, который ожидается.

Для корректной работы, необходимо указать настройку группового отбора «Применение = После группировки или для иерархии», или «Применение = Только иерархия».

При выполнении отбора по детальным записям (на уровне отчета в целом), подобные конструкции также выдают ошибку. Однако, если наложить отбор по группировке «Детальные записи» с применением «После группировки или для иерархии» — он будет работать корректно.

Более подробно про настройку «Применение» групповых отборов смотрите в статье настройки вариантов отчетов.

Еще одно ограничение — функция «ВычислитьВыражение» не учитывает иерархические отборы примененные к группировкам.

 

ВычислитьВыражениеСГруппировкойМассив и ВычислитьВыражениеСГруппировкойТаблицаЗначений

Данные функции очень похожи. Разница состоит в том, что в первом случае возвращаются данные в виде массива, а во втором в виде таблицы значений. Также, вторая функция позволяет в выражении указать несколько полей, перечисленных через запятую. В этом случае, результирующая таблица будет содержать несколько колонок.

Остановимся подробнее на первой функции. Все рассмотренное будет справедливо и для второй.

Полный синтаксис функции следующий:

ВычислитьВыражениеСГруппировкойМассив (Выражение, ВыраженияПолейГруппировки, ОтборЗаписей, ОтборГруппировок) 

Общее описание функции:

Выполнить произвольное выражение в контексте группировок по всем разрезам, указанным в выражении полей группировки и выдать результирующие данные в виде массива.

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

Для примера возьмем предыдущий отчет, и создадим новое вычисляемое поле:

ВычислитьВыражениеСГруппировкойМассив("МАКСИМУМ(Сумма)","Поставщик")

Вычислить выражение с группировкой массив

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

В параметрах «ОтборЗаписей» и «ОтборГруппировок» можно задать отбор, соответственно для детальных записей и для итоговых.

Можно использовать данную функцию в выражениях итогов совместно с агрегатными функциями. Если нужно использовать разные агрегатные функции на разных уровнях группировок, можно использовать вложение одной функции в другую. Например так:

СУММА(ВычислитьВыражениеСГруппировкойМассив("СРЕДНЕЕ(ВычислитьВыражениеСГруппировкойМассив(""МАКСИМУМ(Сумма)"", ""Поставщик, Склад""))", "Склад"))

Или создать вычисляемое поле:

ВычислитьВыражениеСГруппировкойМассив("МАКСИМУМ(Сумма)", "Поставщик, Склад")

А в выражении итогов написать следующее:

СУММА(ВычислитьВыражениеСГруппировкойМассив("СРЕДНЕЕ(ВычисляемоеПоле)", "Склад"))

Подробнее про использование вложенных функций «ВычислитьВыражениеСГруппировкойМассив» смотрите в этой статье.

С групповыми отборами, ситуация аналогична функции «ВычислитьВыражение». Отбор по группировке на поле с выражением «ВычислитьВыражениеСГруппировкойМассив» будет работать корректно, только если используется настройка отбора «Применение = После группировки или для иерархии».

На заметку. В выражениях системы компоновки данных помимо внутренних функций, можно использовать экспортные функции серверных общих модулей (глобальных и не глобальных).

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

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

 

В следующих статьях будут рассмотрены:

  • Использование агрегатных функции СКД,
  • Программная работа с отчетом на СКД,
  • Разработка произвольных макетов.

Для ознакомления с предыдущими статьями можно перейти по ссылкам:

 

Спасибо за внимание.

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

34 Comments

  1. ellavs

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

    Reply
  2. wowik

    Спасибо! только вчера искал ВычислитьВыражение(«Сумма(Количество)», , «ОбщийИтог»)

    Reply
  3. mvgfirst

    Давно ждал — что кто-то сделает описание с картинками )

    И вот это свершилось )…

    Reply
  4. rpgshnik

    Использовал, но так же пока сам не разобрался не понял 🙂

    С картинками пример вообще супер!

    Reply
  5. user805739

    А есть возможность рассказать и про другие функции СКД и их практическое применение? Вроде таких как Корреляция, СтандартноеОтклонениеВыборки, Любой, КлассификацияABC и т.д.

    Reply
  6. Aftee
    Само выражение задается в первом параметра функции

    Опечатка

    Reply
  7. ids79

    (1)Спасибо

    Reply
  8. ids79

    Пожалуйста

    Reply
  9. ids79

    (3)Рад стараться

    Reply
  10. ids79

    (4)Спасибо

    Reply
  11. ids79

    (5)Планирую написать про агрегатные функции.

    Reply
  12. ids79

    (6)Спасибо, исправил

    Reply
  13. MishaD

    Ну вот, а я так надеялся узнать, что за штука такая — группировка не ресурса

    Reply
  14. Yashazz

    Мегаспасибище! Вот наконец хоть кто-то занялся всерьёз.

    Слушайте, а как плюс поставить??? Минус у меня поставился (когда тыркал) а плюс нифига. Куда щёлкать-то?

    Reply
  15. ids79

    (14)Пожалуйста.

    Нажимайте на плюс, и выбирайте раздел, в котором будет сохранена публикация, Загрузки или Избранное.

    Reply
  16. Yashazz

    (15) Ага, спасибо, жмякнул.

    Кстати, у меня лет 6 назад была иллюстрация работы «ВычислитьВыражение» на примере: https://infostart.ru/public/192746/

    Reply
  17. ids79

    (16)Посмотрел, интересно.

    П.С. А плюсик так и не поставили :))

    Reply
  18. Yashazz

    (17) Поставил!!! Сделал, как Вы сказали!

    Reply
  19. echo77

    (1) нужно сделать двойное агрегирование: Сумма(Вычислить выражением группировкой массив())

    Reply
  20. ids79

    (19)А это не двойное агрегирование. ВычислитьВыражениеСГруппировкойМассив — не агрегатная функция. А про вложенные функции написано кратно + ссылка на статью, где более подробно.

    Reply
  21. echo77

    (20) сама по себе нет, но внутри, можно расположить агрегатную функцию

    Reply
  22. ids79

    (21)Ну это да, в этом ее смысл. Если интересно про вложенные функции, посмотрите по ссылки из статьи.

    Reply
  23. djan

    Спасибо за статью — наглядно, доступно. Я вот давеча пробовал с помощью функции ВычислитьВыражение получить в итоге группировки значение последней строки из этой группировки. Так и не получилось у меня это сделать. Если знаете, подскажите пожалуйста, для общего развития..

    Reply
  24. ids79

    (23)Посмотрите комментариях к этой статье Был такой же вопрос.

    Reply
  25. tireal

    «Если выражение рассчитывается по группировке, отбор записей выполняется на уровне этой группировки. Текущей в данном случае будет родительская группировка:» у меня выражение (разность дат между текущей строкой и предыдущей) рассчитывается без указания группировки (2 параметр), т. е. если верить описанию в контексте текущей группировки. В детальных записях все норм, но как только я пытаюсь получить по полученным в детальных записях значениям итоги (Сумма(Разность дат) — функция как понимаю игнорирует эти данные и в итог группировки рассчитывает как разность дат последней записи пред. группировки и первой текущей.

    Как же мне посчитать итоги именно по значениям детальных записей кто скажет?

    Reply
  26. tireal

    вроде решил, вместо Сумма(Разность дат) в выражении итога нужно было Сумма(ВычислитьВыражениеСГруппировкойМассив(Разность дат))

    Reply
  27. ids79

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

    В Вашем случае нужно в итогах сделать так:

    СУММА(ВычислитьВыражениеСГруппировкойМассив(«РазностьДат», «Документ»)).

    Документ — это любой реквизит из детальных записей.

    Тогда расчет будет корректный.

    Reply
  28. tireal

    (27) да спасибо, уже нашел. Но! ) теперь какие то странные общие итоги…

    Reply
  29. tireal

    (27) убрал Сумма в СУММА(ВычислитьВыражениеСГруппировкойМассив(«РазностьДат», «Документ»)). — решил посмотреть из каких сумм складывается Общий итог — только первая совпадает с итогом по первой группировке а остальное ….

    Буду очень признателен если поделитесь мыслями почему так может быть

    Reply
  30. ids79

    (29)Да, не будет общий итог работать. Так как нарушается корректная последовательность для определения предыдущей записи.

    Нужно сделать примерно как описано тут

    Для общего итога отдельный расчет с вложенными друг в друга функциями ВычислитьВыражениеСГруппировкойМассив.

    Reply
  31. lmnlmn
    Существует еще загадочное значение «ГруппировкаНеРесурса»…

    Мне не доводилось использовать данное значение. Проводя эксперименты, каких-то отличий применения данного значения от значения «Группировка», я не выявил. Очень может быть, что это значение не актуально на сегодняшний день.

    Если кто-то использовал это значение, напишите, пожалуйста, в комментариях, очень интересно!

    Намедни довелось прибегнуть с этому средству. Есть справочник с иерархией групп и элементов. Небезывестно, что с ними есть проблема с дублями при выводе иерархии. Так вот «ГруппировкаНеРесурса» берет значения ресурсов как раз из этих «дублей» и рисует их на уровне группировки.

    У меня была задача вывести привязку пользователей к группам номенклатуры в виде кросс-таблицы где по горизонтали пользователи, а по вертикали группы номенклатуры с учетом их иерархии в справочнике. На пересечении «галочка» — булево. Что-то типа «все роли» в конфигураторе только еще с сохранением иерархии групп по строкам. «ГруппировкаНеРесурса» позволяет выводить «галочки» только в том случае, если у пользователя есть право на использование именно этой группы не взирая на дочерние. При других типах расчета мы получим «галочку» при наличии прав на любую из дочерних групп, что мне совершенно не годилось.

    P.S. Извиняюсь за сумбур в описании. Понимать и исследовать как это работает совершенно некогда.

    Reply
  32. Shaldryn

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

    Reply
  33. ids79

    (32)Можно сделать отдельный расчет итогов для товаров и для Иерархии товаров.

    Для иерархии использовать такую формулу:

    ВычислитьВыражение(«Сумма(Количество)», «Товар»)

    Reply
  34. Shaldryn

    (33) Да, получилось, спасибо большое

    Reply

Leave a Comment

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