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

27.02.20

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

 

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

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

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

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

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

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

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

 

Группировка

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

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

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

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

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

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

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

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

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

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

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

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

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

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

 

Тип расчета

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

 

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

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

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

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

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

И

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

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

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

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

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

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

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

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

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

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

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

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

 

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

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

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

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

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

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

 

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

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

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

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

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

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

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

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

 

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

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

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

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

 

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

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

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

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

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

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

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

Поле1

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

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

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

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

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

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

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

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

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

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

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

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

 

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

 

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

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

 

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

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

внутренние функции СКД вычислить выражение с группировкой массив

См. также

SALE! 20%

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

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

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

13000 10400 руб.

02.09.2020    122112    670    389    

714

Генератор схемы компоновки данных (СКД), написание кода схемы программно

Инструментарий разработчика СКД Платформа 1С v8.3 Конфигурации 1cv8 1С:Зарплата и Управление Персоналом 3.x Абонемент ($m)

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

3 стартмани

05.02.2024    4038    25    obmailok    17    

63

Набор-объект для СКД по тексту или запросу

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

Есть список полей в виде текста, или запрос - закидываем в набор СКД.

1 стартмани

31.01.2024    2000    2    Yashazz    0    

29

СКД на JavaScript в 1С

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

Долгое время поддерживаю web-портал, в котором появилась необходимость создавать отчеты. Просмотрев различные фреймворки на js, я решил сделать свое решение, которое позволяло бы быстро разрабатывать и добавлять новые отчеты на web-портал.

2 стартмани

11.12.2023    8158    20    John_d    25    

123

Использование менеджера временных таблиц в СКД

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

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

05.12.2023    4653    PROSTO-1C    13    

61

Модель СКД

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

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

1 стартмани

15.11.2023    5806    15    kalyaka    5    

86

Пользовательские настройки отчетов 1С. Часть 1. Простые и расширенные настройки

СКД Инструкции пользователю Платформа 1С v8.3 Конфигурации 1cv8 1С:Бухгалтерия 3.0 Россия Бесплатно (free)

Простые приемы работы с отчетами на СКД. Что нужно знать пользователю про настройку отчетов, чтобы использовать их на полную катушку.

18.09.2023    6701    accounting_cons    5    

29

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

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

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

01.09.2023    4520    KVIKS    15    

80
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. ellavs 1022 08.08.19 11:37 Сейчас в теме
Вот спасибо, только вчера искала решение по нестандартному итогу: нужно было сделать общий итог в виде суммы по группировкам, в которых итог рассчитывался как максимальное значение по группировке. Набегом не получилось. Снова попытаюсь с Вашей статьей :)
ikalmykia; user712426; user712389; Ali_q; Михаська; Drivingblind; ids79; +7 Ответить
7. ids79 8291 08.08.19 16:28 Сейчас в теме
19. echo77 1868 19.08.19 15:51 Сейчас в теме
(1) нужно сделать двойное агрегирование: Сумма(Вычислить выражением группировкой массив())
katakuna; +1 Ответить
20. ids79 8291 19.08.19 16:56 Сейчас в теме
(19)А это не двойное агрегирование. ВычислитьВыражениеСГруппировкойМассив - не агрегатная функция. А про вложенные функции написано кратно + ссылка на статью, где более подробно.
21. echo77 1868 19.08.19 17:02 Сейчас в теме
(20) сама по себе нет, но внутри, можно расположить агрегатную функцию
22. ids79 8291 19.08.19 17:49 Сейчас в теме
(21)Ну это да, в этом ее смысл. Если интересно про вложенные функции, посмотрите по ссылки из статьи.
2. wowik 885 08.08.19 11:43 Сейчас в теме
Спасибо! только вчера искал ВычислитьВыражение("Сумма(Количество)", , «ОбщийИтог»)
8. ids79 8291 08.08.19 16:30 Сейчас в теме
3. mvgfirst 6 08.08.19 11:44 Сейчас в теме
Давно ждал - что кто-то сделает описание с картинками )
И вот это свершилось )...
Serg243; Ali_q; Михаська; murat_; ids79; +5 Ответить
9. ids79 8291 08.08.19 16:31 Сейчас в теме
4. rpgshnik 3631 08.08.19 12:16 Сейчас в теме
Использовал, но так же пока сам не разобрался не понял :)
С картинками пример вообще супер!
ids79; SmArtist; +2 Ответить
10. ids79 8291 08.08.19 16:31 Сейчас в теме
5. Mx-RoN 08.08.19 12:40 Сейчас в теме
А есть возможность рассказать и про другие функции СКД и их практическое применение? Вроде таких как Корреляция, СтандартноеОтклонениеВыборки, Любой, КлассификацияABC и т.д.
TeMochkiN; scanner1980; +2 Ответить
11. ids79 8291 08.08.19 16:32 Сейчас в теме
(5)Планирую написать про агрегатные функции.
user712426; TeMochkiN; +2 Ответить
6. Aftee 08.08.19 13:28 Сейчас в теме
Само выражение задается в первом параметра функции

Опечатка
12. ids79 8291 08.08.19 16:35 Сейчас в теме
(6)Спасибо, исправил
13. MishaD 14 09.08.19 16:26 Сейчас в теме
Ну вот, а я так надеялся узнать, что за штука такая - группировка не ресурса
14. Yashazz 4709 11.08.19 10:30 Сейчас в теме
Мегаспасибище! Вот наконец хоть кто-то занялся всерьёз.

Слушайте, а как плюс поставить??? Минус у меня поставился (когда тыркал) а плюс нифига. Куда щёлкать-то?
15. ids79 8291 11.08.19 11:32 Сейчас в теме
(14)Пожалуйста.
Нажимайте на плюс, и выбирайте раздел, в котором будет сохранена публикация, Загрузки или Избранное.
16. Yashazz 4709 12.08.19 10:50 Сейчас в теме
(15) Ага, спасибо, жмякнул.
Кстати, у меня лет 6 назад была иллюстрация работы "ВычислитьВыражение" на примере: https://infostart.ru/public/192746/
17. ids79 8291 12.08.19 20:32 Сейчас в теме
(16)Посмотрел, интересно.

П.С. А плюсик так и не поставили :))
18. Yashazz 4709 12.08.19 22:30 Сейчас в теме
(17) Поставил!!! Сделал, как Вы сказали!
23. djan 15.10.19 12:36 Сейчас в теме
Спасибо за статью - наглядно, доступно. Я вот давеча пробовал с помощью функции ВычислитьВыражение получить в итоге группировки значение последней строки из этой группировки. Так и не получилось у меня это сделать. Если знаете, подскажите пожалуйста, для общего развития..
24. ids79 8291 15.10.19 18:03 Сейчас в теме
(23)Посмотрите комментариях к этой статье Был такой же вопрос.
25. tireal 74 24.10.19 10:57 Сейчас в теме
"Если выражение рассчитывается по группировке, отбор записей выполняется на уровне этой группировки. Текущей в данном случае будет родительская группировка:" у меня выражение (разность дат между текущей строкой и предыдущей) рассчитывается без указания группировки (2 параметр), т. е. если верить описанию в контексте текущей группировки. В детальных записях все норм, но как только я пытаюсь получить по полученным в детальных записях значениям итоги (Сумма(Разность дат) - функция как понимаю игнорирует эти данные и в итог группировки рассчитывает как разность дат последней записи пред. группировки и первой текущей.

Как же мне посчитать итоги именно по значениям детальных записей кто скажет?
27. ids79 8291 24.10.19 13:23 Сейчас в теме
(25)Проблема в том, что на уровне группировки функция ВычислитьВыражение будет уже работать не с детальными записями, а с группировками.
В Вашем случае нужно в итогах сделать так:
СУММА(ВычислитьВыражениеСГруппировкойМассив("РазностьДат", "Документ")).
Документ - это любой реквизит из детальных записей.
Тогда расчет будет корректный.
28. tireal 74 24.10.19 14:20 Сейчас в теме
(27) да спасибо, уже нашел. Но! ) теперь какие то странные общие итоги...
Прикрепленные файлы:
29. tireal 74 24.10.19 15:32 Сейчас в теме
(27) убрал Сумма в СУММА(ВычислитьВыражениеСГруппировкойМассив("РазностьДат", "Документ")). - решил посмотреть из каких сумм складывается Общий итог - только первая совпадает с итогом по первой группировке а остальное ....

Буду очень признателен если поделитесь мыслями почему так может быть
Прикрепленные файлы:
30. ids79 8291 24.10.19 16:02 Сейчас в теме
(29)Да, не будет общий итог работать. Так как нарушается корректная последовательность для определения предыдущей записи.
Нужно сделать примерно как описано тут
Для общего итога отдельный расчет с вложенными друг в друга функциями ВычислитьВыражениеСГруппировкойМассив.
26. tireal 74 24.10.19 12:13 Сейчас в теме
вроде решил, вместо Сумма(Разность дат) в выражении итога нужно было Сумма(ВычислитьВыражениеСГруппировкойМассив(Разность дат))
31. lmnlmn 69 27.11.19 10:50 Сейчас в теме
Существует еще загадочное значение «ГруппировкаНеРесурса»...

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

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

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

P.S. Извиняюсь за сумбур в описании. Понимать и исследовать как это работает совершенно некогда.
mangy; Spacer; o.nikolaev; fokses; +4 Ответить
32. Shaldryn 16.12.19 09:47 Сейчас в теме
Спасибо за статью, у меня вопрос, как можно сделать чтобы для каждой группы выводилось их сумма как по элементам, так и по группе?
Прикрепленные файлы:
33. ids79 8291 16.12.19 10:11 Сейчас в теме
(32)Можно сделать отдельный расчет итогов для товаров и для Иерархии товаров.
Для иерархии использовать такую формулу:
ВычислитьВыражение("Сумма(Количество)", "Товар")
Shaldryn; +1 Ответить
34. Shaldryn 16.12.19 11:31 Сейчас в теме
(33) Да, получилось, спасибо большое
35. gorakh 26 31.01.20 11:23 Сейчас в теме
Есть колонка полученная пометодике описанной "итоги по строкам таблицы ресурсы, отличные от ресурсов в колонках таблицы" . Как можно испоьзовать результаты полученные в ней в контексте ВычислитьВыражение?
36. ids79 8291 04.02.20 09:35 Сейчас в теме
(35)Я думаю, что никак.
37. temdj 13 27.05.20 14:20 Сейчас в теме
Добрый день, Суммы это конечно хорошо) Не пойму, как можно сделать разность между текущей и предыдущей группировкой, чтобы получить дельту (отклонение) по периоду.
38. dmitryts 2 25.06.20 16:15 Сейчас в теме
Добрый день

В СКД уже могу многое, но вот эти функции никак не даются.
В приложении схема, которая пока у меня не работает. Вернее, не работают именно поля, которые рассчитываются этими функциями.
Если я убираю эти поля из группировки сделка, то все работает. А с ними получаю сообщение "Выражение не может быть вычислено ..."
Я так понимаю, программа пытается эти поля вычислить не для группировки Сделка...
Что не так?
Мне нужно вычислить Рентабельность по формуле (Выручка - СУММА (Затраты)) / Рентабельность

Я понимаю, что именно этот отчет можно посчитать и без этих функций. Но надо же когда-то начать! Поможете найти ошибку?
Прикрепленные файлы:
рентабельность.xml
39. ids79 8291 27.06.20 11:22 Сейчас в теме
(38)А зачем Вы добавляете эти поля в группировку "Сделка"?
Удалите их и добавьте как ресурсы, только без агрегатной функции.
Тогда не должно быть ошибки.
И еще, "ОбщийИтог" в формуле, по моему его там быть не должно.
40. user_2010 871 29.06.20 15:27 Сейчас в теме
Добрый день!
Кручу-верчу... запутать хочу :)
И так и эдак - не выходит каменный цветок...

Может быть, кто-то гуру этих самых функций подскажет как такое возможно настроить?

Нужно посчитать переработки и недоработки
Отчет в виде таблицы:
Колонки - группировка по месяцам + итого за весь период.
Строки - группировки по Организация, сотрудник.

При расчете итого за период - нужно сложить за все месяца переработки/недоработки и если
Всего по сотруднику за период > 0 = переработка,
Всего по сотруднику за период < 0 = недоработка.

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


Для примера с цифрами

Иванов январь всего переработка/недоработка = -10 (< 0 => это недоработка)
Иванов февраль всего переработка/недоработка = +7 ( > 0 => это переработка)

Иванов Итого за период = -3 (< 0 => это недоработка)

Петров январь всего переработка/недоработка = +8 ( > 0 => это переработка)
Петров февраль всего переработка/недоработка = -6 (< 0 => это недоработка)

Петров Итого за период = +2 ( > 0 => это переработка)

Табличка:

Январь Февраль Итого за период
Всего Недораб Перераб Всего Недораб Перераб Всего Недораб Перераб
Иванов -10 -10 +7 +7 -3 -3
Петров +8 +8 -6 -6 +2 +2
Итого по орг -2 -10 +8 +1 -6 +7 -1 -3 +2

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

Возможно это настроить?

Спасибо!
41. Pryanishnikov_Vladimir 24.07.20 14:20 Сейчас в теме
Возможно ли получить значение первой записи в группировке?
Прикрепленные файлы:
43. ids79 8291 31.07.20 14:11 Сейчас в теме
(41) Первое, что нужно сделать, это сделать разные формулы расчета итогов для иерархии и для элементов.
Для иерархии, в расчете вообще убрать агрегатную функцию. По по-моему этого достаточно, чтобы выводилась первая запись группы.
42. LIL_PIVO 1 31.07.20 07:34 Сейчас в теме
Добрый день!

Помогите убрать записи по ресурсам из детальных записей, но оставить их в итогах. СКД формирую программно

Строка создания ресурса ( структура передаётся в процедуру подстановки ресурсов для СКД)
СтруктураРесурсов.Вставить("ДебетНачальный", "Сумма(ВычислитьВыражениеСГруппировкойМассив(""Минимум(ДебетНачальный)"",""Точка""))");

Картина получается такая ( картинка во вложении).

Пробовал добавлять ещё один ресурс
ПолеРесурса = СхемКомпДанных.ПоляИтога.Добавить();
ПолеРесурса.ПутьКДанным = "ДебетНачальный";
ПолеРесурса.Выражение = "ВычислитьВыражение( ""0"",""ДебетНачальный"",""ДебетНачальный"")";
Прикрепленные файлы:
44. ids79 8291 31.07.20 14:21 Сейчас в теме
(42) Не очень понял, зачем Вы используете функцию ВычислитьВыражениеСГруппировкойМассив…
Попробуйте сделать так:
СтруктураРесурсов.Вставить("ДебетНачальный", "Минимум(ДебетНачальный)","Точка");
45. LIL_PIVO 1 31.07.20 14:55 Сейчас в теме
(44)
Суммирую, чтоб подсчитал общий итог.

Попробуйте сделать так:
СтруктураРесурсов.Вставить("ДебетНачальный", "Минимум(ДебетНачальный)","Точка");

Не помогло.


Подскажите пожалуйста, а настройки вывода полей по детальным записям как программно отредактировать?
Чтоб было типа такого
https://forum.infostart.ru/forum9/topic58095/
46. ids79 8291 31.07.20 15:04 Сейчас в теме
(45)Я не знаю, не пробовал так делать. Но, по идеи должно быть примарно так как я написал.

"Суммирую, чтоб подсчитал общий итог. "
Это имело бы смысл, для группировок более высокого уровня, чем "Точка".
А так будет тот же результат, что и Минимум(ДебетНачальный)
47. LIL_PIVO 1 31.07.20 15:06 Сейчас в теме
(46) Спасибо, попробую переделать структуру отчета
48. LIL_PIVO 1 31.07.20 16:09 Сейчас в теме
(46) Придумал ужасное решение. Т.к. знаю номера ячеек у ресурсов и у области итогов цвет жирный, скрываю записи у которых это ложь. На выходных всё же надо придумать другой способ

НомерСтр = 9; 
	Пока НомерСтр <> 200 Цикл
		
		Если Результат.Область("R" + Строка(НомерСтр) + "C3").Шрифт.Жирный = Ложь Тогда
			
			Результат.Область("R" + Строка(НомерСтр) + "C3").Текст = "";
			Результат.Область("R" + Строка(НомерСтр) + "C4").Текст = "";
			Результат.Область("R" + Строка(НомерСтр) + "C7").Текст = "";
			Результат.Область("R" + Строка(НомерСтр) + "C8").Текст = "";
			
		КонецЕсли;
		
		НомерСтр = НомерСтр + 1; 
	КонецЦикла;
Показать
49. ids79 8291 01.08.20 10:09 Сейчас в теме
(48)Да, это не очень вариант
54. Suslik_Johns 26.11.20 16:16 Сейчас в теме
(48) зато оригинально)))
Dmitri93; +1 Ответить
80. VladIsLooove23 28.04.22 06:54 Сейчас в теме
(48) Сделал чтото похожее чтобы конечный остаток получить из последней таблицы
Процедура РассчитатьОстаток()
	
	Строка = "R";
	Столбец = "C";
	
	ПоследняяСтрокаДанных = ЭтотОбъект.ОтчетТабличныйДокумент.ВысотаТаблицы - 1;
	ОбластьПоследнегоСтолбцаПоследнейСтроки = Строка + ПоследняяСтрокаДанных + Столбец + 15; 
	КонечныйОстаток = ЭтотОбъект.ОтчетТабличныйДокумент.Область(ОбластьПоследнегоСтолбцаПоследнейСтроки).Текст;
	ОбластьОстаткаВкроссТаблице = Строка + 4 + Столбец + 4;
	
	ЭтотОбъект.ОтчетТабличныйДокумент.Область(ОбластьОстаткаВкроссТаблице).Текст = КонечныйОстаток;
	
КонецПроцедуры
Показать

На код-ревью поррекомендовали переделать на вычислить выражение... Но я пробовал уже вычислить выражение... не работает((( хз что не так делаю, кто в курсе подскажите.
50. hiduk 124 06.11.20 10:40 Сейчас в теме
Спасибо за статью, познавательно.

После прочтения остались вопросы:
1) Как и для чего использовать параметры «ОтборЗаписей» и «ОтборГруппировок»?
2) Функция языка выражений СКД "ВычислитьВыражениеСГруппировкойТаблицаЗначений" является аналогом агрегатной функции "ТаблицаЗначений", но с дополнительными параметрами/возможностями?
51. ids79 8291 06.11.20 14:45 Сейчас в теме
(50) Добрый день
1. Параметр "Отбор записей" позволяет указать выражение для отбора детальных записей, которые будут обрабатываться, "ОтборГруппировок" - можно указать выражение для отбора уже сгруппированных строк. Как я понимаю, агрегатная функция в отборе группировок должна соответствовать агрегатной функции в выражении.
2. Я бы сказал, это объединение функциональности функций ВычислитьВыражение и ТаблицаЗначений
52. dvsidelnikov 64 24.11.20 20:13 Сейчас в теме
Спасибо, мил человек! Дай Бог вам здоровья!
53. Suslik_Johns 26.11.20 16:14 Сейчас в теме
А что делать в случае, если есть поле, содержащее ВычислитьВыражение(), а нужно еще применить условное оформление?
Так и не удалось этого сделать... Кто-нибудь использовал их совместно?
55. ids79 8291 26.11.20 19:56 Сейчас в теме
(53)А в чем сложность возникла?
56. Suslik_Johns 27.11.20 10:50 Сейчас в теме
(55) колонка выводит данные нарастающим итогом с помощью функции ВычислитьВыражение(). Я хочу выводить только положительные значения. Создаю условное оформление на высоту строки - система ругается. Хочу выделять цветом положительные значения - также ругается при формировании отчета. Ошибка такая же, как если бы делали отбор в этой колонке. Может, конечно, что-то не так делаю...
57. mralexeydoc 28.01.21 22:36 Сейчас в теме
Добрый день!
Бьюсь уже который день с группировками.
У меня выводятся в отчет данные плановых и фактических данных (будем называть их "Ссылки") в иерархии, где каждый узел иерархии выступает группировкой. Плановые значения лежат уже в регистре в сгруппированном виде (т.е., при записи документа, в регистр попадают данные в том виде, в котором они должны отображаться в отчете)
Перепробовал много чего и все-равно не понимаю, что не так.

Что, собственно, нужно:
1. Для колонки "Факт" группировки должны рассчитываться (с этим проблем нет, все норм - группировка делает свое);
2. Для колонки "План" - суммы должны подставляться в том же виде, как они лежат в регистре. На уровне СКД группироваться результирующие плановые данные не должны.
Особенность состоит в том, что на уровне запроса данные не группируются, поскольку в расшифровке по колонке "План" нужно отслеживать динамику изменений сумм (каким регистратором были скорректированы суммы), в том числе, и самой родительской ссылке, плюс еще дополнительно выводится множество колонок с данными для анализа.

Во вложении прикрепил скрин, как это все выглядит, для понимания.
Может подскажет кто, в каком русле копать.
Спасибо!
Прикрепленные файлы:
58. ids79 8291 29.01.21 17:11 Сейчас в теме
(57)Если я правильно понял проблему, Вам нужно в ресурсах для поля "План" убрать агрегатную функцию. Оставить только само поле.
59. Vladimir-R 167 12.02.21 15:55 Сейчас в теме
Добрый день!
Как получить первое и последнее значение внутри группировки в ресурсах?
Эти вариант не проходят
ВЫЧИСЛИТЬВЫРАЖЕНИЕ("ОстатокНаНачало", "Сотрудник","Группировка", "Первая","Первая")
ВЫЧИСЛИТЬВЫРАЖЕНИЕ("ОстатокНаКонец", "Сотрудник", "Группировка" ,"Последняя " ,"Последняя ")

группировки Сотрудник, ДатаПериода.
Остаток на начало/конец вычисляется на каждую ДатаПериода
необходимо, чтобы на начало по сотрудникам попадал остаток на начало по самой первой ДатаПериода, остаток на конец - соответственно по самой последеней ДатаПериода
60. ids79 8291 12.02.21 20:04 Сейчас в теме
(59)Попробуйте вместо Сотрудник указать группировку ДатаПериода. Ну и агрегатную функцию какую-нибудь указать.
61. zenechka 542 20.02.21 11:26 Сейчас в теме
А возможно такое сделать в СКД? :)
Для первой группировки нужно взять сумму максимальных записей по полям детальных записей...
А следующие группировки должны получаться суммированием нижлежайших.. (кроме нулевой)...
Прикрепленные файлы:
62. zenechka 542 20.02.21 12:44 Сейчас в теме
(61)

Группировку 1-го уровня получилось посчитать так....
Сумма(ВычислитьВыражениеСГруппировкойМассив("Максимум(Ресурс1)", "Группировка0"))


а как теперь проссуммировать эти значения на группировках верхних уровней ?
63. zenechka 542 20.02.21 13:00 Сейчас в теме
(62)
Сумма(ВычислитьВыражениеСГруппировкойМассив("Максимум(Ресурс1)", "Группировка0"))


Вроде как раз то что нужно получилось...

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

Спасибо за статью...
64. sacred 173 10.03.21 05:39 Сейчас в теме
А вот если отчёт выводится в таблицу, и есть группировки строки и группировки колонки, то которые из них считаются выше, а которые - ниже? Как в этом случае использовать второй параметр функции ВычислитьВыражение()? Особенно интересует отбор по итогам.
65. ids79 8291 14.03.21 18:52 Сейчас в теме
(64)Я не пробовал так делать. Попробуйте и напишите что получилось.
66. Tocaelectro 15.03.21 21:02 Сейчас в теме
Добрый день!
Не получается для иерархического справочника на уровне самой иерархии выводить значения реквизитов справочника. Если реквизиты переквалифицировать в ресурсы, то не получается на группировке вытащить значение элементы справочника, вместо того, чтобы система автоматом не подсчитывала агрегатные значения. Может есть какие-то идеи. Спасибо.
Прикрепленные файлы:
67. HystriX 31.03.21 18:50 Сейчас в теме
По поводу "ГруппировкаНеРесурса" - поведение будет отличаться, если в структуре использована группировка по ресурсу. Если группировки по ресурсу нет, поведение не отличается от обычного варианта "Группировка". Эта особенность описана в книге "Руководство разработчика.
68. unknow_user 15.04.21 08:43 Сейчас в теме
Доброго времени! Статья полезная. Подскажите где ошибся?

ВычислитьВыражение("Сумма(НачальныйОстаток) + Сумма(НачисленоПриход) - Сумма(НачисленоРасход)","Регистратор", "Группировка")


Хочу расчитать "Конечный остаток" для группировки "Регистратор". Рассчитывать по поставил "Регистратор", но поле "Конечный остаток пустое"
69. unknow_user 15.04.21 09:16 Сейчас в теме
(68) Разобрался, у меня начальный остаток не рассчитывается по регистратору и это так повлияло. Буду копаться дальше, механизм нужный
70. пользователь 26.04.21 22:28
Сообщение было скрыто модератором.
...
71. Letos 266 12.06.21 00:12 Сейчас в теме
Борого дня. Тоже нужна помощь.
Отчет вид "Таблица".
Строки: Контрагент, Договор.

Одно из колонок (Поле1) расчитываю следующим образом:

ВычислитьВыражение("Максимум(Процент)","ДоговорКонтрагента") / 100 * СуммаОбщаяСмета

На вкладке Ресурсы закидываю расчитываемое поле в Сумму

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

По договорам все хорошо, Но нет итогов по Контрагенту. Что нужно добавить и куда?
72. ids79 8291 12.06.21 11:18 Сейчас в теме
(71)Да, так работать не будет. Так как Вы принудительно вычисляете выражение по группировка "ДоговорКонтрагента". А на уровне контрагента ее нет.
В зависимости от того, что Вы хотите сделать, посчитать максимальный процент по контрагенту или сложить все значения по договорам, Вам нужно или очистить поле Группировка (для первого варианта) или использовать в ресурсах для группировки "Контрагент" функцию ВычислитьВыражениеСГруппировкойМассив.
Что-то типа такого:
СУММА(ВычислитьВыражениеСГруппировкойМассив(СУММА(Поле1), "ДоговорКонтрагента"))
73. Letos 266 12.06.21 12:47 Сейчас в теме
(72) Почему не показывается итог по Контрагенту мне было понятно. (благодаря статье).

Дело в том, что НЕ вовсех договорах есть "Процент", если использовать группировку по контрагенту, то из-за "Максимум(Процент)" в Договорах в которых НЕТ процента, начинает считаться процент. (P.S. не использовать Максимум не получается)

Если вставить Ресурсы:

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

То выдает ошибку: "Использование вложенных агрегатных функций не возможно"

Если использую: ВычислитьВыражениеСГруппировкойМассив(СУММА(Поле1), "ДоговорКонтрагента")

То итог для контрагента пересчитывается как при группировке по Контрагенту,то есть процент пересчитывается и для тех договоров где Процента нет.
74. ids79 8291 17.06.21 11:12 Сейчас в теме
(73) Так сложно что-то еще посоветовать, не видя данные и сам отчет.
Если сбросите схему компоновки, могу посмотреть.
75. Zlaya-Ferio 3 24.06.21 14:31 Сейчас в теме
ВычислитьВыражение("Сумма(Количество)", "Товар", "Иерархия")

У меня не работает эта схема((( пишу
ВЫБОР
	КОГДА (Показатели.Количество.КоличествоНачальныйОстаток>0 ИЛИ Показатели.Количество.КоличествоКонечныйОстаток>0) И (Показатели.Количество.КоличествоРасход/((Показатели.Количество.КоличествоНачальныйОстаток+Показатели.Количество.КоличествоКонечныйОстаток)/2))>0 
	ТОГДА ВычислитьВыражение("Показатели.Количество.КоличествоРасход/((Показатели.Количество.КоличествоНачальныйОстаток+Показатели.Количество.КоличествоКонечныйОстаток)/2)","АналитикаНоменклатуры.Номенклатура","Иерархия")
	ИНАЧЕ 0 
КОНЕЦ

по позициям считает. в иерархии нет(( что не так? окиньте свежим взором!))
76. ids79 8291 01.07.21 19:29 Сейчас в теме
(75)У Вас не указана сама агрегатная функция в ВычислитьВыражение. Если ее нет, берется первая строка в группировке. Видимо используя тип группировки Иерархия, это не работает.
77. yarrr 8 11.01.22 22:16 Сейчас в теме
Подскажите, пожалуйста, есть ли с помощью функций ВычислитьВыражение возможность рассчитать итоги за конкретный период с указанием дат? Например, нужны итоги за месяц отчета, итоги с начала квартала по дату отчета, итоги с начала года по дату отчета. Имею выборку плановых и фактических значений показателя за 2 года, необходимо получить такие итоги за текущий год и аналогичные периоды предыдущего года.
78. yarrr 8 13.01.22 15:33 Сейчас в теме
(77) решил свой вопрос. Добавил в запрос 3 поля для группировки, в которых соответственно помечаются строки, попадающие в период с начала года, с начала квартала и за тек месяц. Затем во вкладке Ресурсы для ресурсов План и Факт оставил стандартное выражение расчета итогов и установил пометки расчета итогов только по этим 3 полям группировки. Предполагаю по аналогии получить и итоги за прошлый год.
79. tpash 5 31.01.22 13:36 Сейчас в теме
Возник вопрос по статье.
А сколько раз можно указывать вложенные группировки в функции ВычислитьВыражениеСГруппировкойМассив и каков будет сиснтантаксис
при вложении например трех функций?
Про два понятно: там двойные ковычки во вложенной функции.
81. 4ytta 24 24.06.22 13:45 Сейчас в теме
(79)
сколько раз можно указывать вложенные группировки в функции ВычислитьВыражениеСГруппировкойМассив

у вас получилось вставить более двух вложений? Весь инет обрыл, везде предлагают только два вложения...
82. ids79 8291 24.06.22 13:48 Сейчас в теме
(81)Я не пробовал. Попробуйте, напишите.
newvideo; +1 Ответить
83. 4ytta 24 24.06.22 13:53 Сейчас в теме
(82)вот как раз сижу и пытаюсь, с этими кавычками запутался, по какому правилу они тут расставляются, если три вложения, то три кавычки или как...? вот какая формула у меня: Среднее(ВычислитьВыражениеСГруппировкойМассив("Среднее(ВычислитьВыражениеСГруппировкойМассив("
Среднее(ВычислитьВыражениеСГруппировкойМассив(""Сумма(Значение)"",""Смена""))"
,"Период"))","ТО"))
84. tpash 5 02.07.22 10:34 Сейчас в теме
(83)
Я в итоге отчет переделал, чтобы не было такой большой вложенности. Но по сути ответа на свой вопрос так и не нашел. А у вас не получилось?
96. ILM 240 31.01.23 08:20 Сейчас в теме
(81) Получилось сделать через вычисляемые поля.
Например
Долг - ВЫБОР КОГДА ТипЗаказа = 1 ТОГДА Сумма(Приход)-Сумма(Расход) .... КОНЕЦ
Долг1 - ВычислитьВыражение("Сумма(Долг)", "Заказ")
Долг2 - ВычислитьВыражение("Сумма(Долг1)", "Номенклатура")
Долг3 - ВычислитьВыражение("Сумма(Долг2)", "Подразделение")
85. newvideo 19.07.22 12:08 Сейчас в теме
Спасибо за статью.
У меня таблица СКД (колонки, строки)
Я хочу в ресурс по колонке передать значение предыдущей группировки (ресурса).
Получилось ВычислитьВыражение("Сумма(СписочныйСостав)", "Период", ,"Предыдущая", "Предыдущая")
Но в отчете первая колонка пустая, так как для первой группировки отсутствует предыдущая.
сделал проверку на МестоВПорядке. Если это первая группировка, то брать значения текущей группировки.
Работает, но наткнулся на случай, когда для первой группировки колонки для конкретных строк отсутствуют ресурсы (значения) и тогда вторая колонка становится №1 и берет текущие значения, а мне нужно всё же всегда брать из первой, даже если там 0.
Есть ли ещё функция для определения номера группировки?
86. ids79 8291 20.07.22 19:10 Сейчас в теме
(85)Так МестоВПорядке же и определяет... Или я Вас не правильно понял. Скиньте сам запрос, так нагляднее будет.
91. newvideo 28.07.22 09:50 Сейчас в теме
(86)Запрос тут не причем. Место в порядке определяет место группировки колонки только если задать сортировку строк, странное решение.
Если сделать сортировку строк, а скажем в пересечении первой строки и колонки будет 0, а во второй строке будет 1, то строки отсортируются по этим значениям и номер колонки также изменится, если ресурс в колонке = 0, тогда функция будет возвращать номер колонки №1 для колонки, в которой ресурс не 0. Я не понимаю как сортировка строк вообще имеет отношение к определению номера колонки.
87. user1274184 27.07.22 08:46 Сейчас в теме
Дмитрий, на Вас последняя надежда!)

Выбираю запросом в СКД поля Номенклатура, Сумма и Количество. Есть Вычисляемое поле, считающее %. В ресурсах Сумма(Сумма) и Сумма(Количество).
Надо посчитать Вычисляемое поле по группировке Номенклатура. В ресурсы добавляю ВычислитьВыражение(Сумма(Сумма), "Номенклатура") и в результате выполнения отчета получается "синтаксическая ошибка", причем ВычислитьВыражение(Сумма(Количество), "Номенклатура") прекрасно работает. Думал, что это из-за денежного поля Сумма, но приведение к числу тоже ничего не изменило.

Подскажите, пожалуйста, в чем может быть дело?
88. ids79 8291 27.07.22 09:27 Сейчас в теме
(87) Так тоже не работает:
ВычислитьВыражение("Сумма(Сумма)", "Номенклатура")
?
89. user1274184 27.07.22 09:51 Сейчас в теме
(88) не работает, синтаксическая ошибка
90. ids79 8291 27.07.22 11:46 Сейчас в теме
(89)Так сложно сказать. Нужно запрос смотреть и схему компоновки )).
92. NikolaST 4 22.09.22 09:47 Сейчас в теме
Есть СКД в структуре Таблица. Мне надо в каждой колонке таблицы получить значение итого по текущей группировке, что бы потом процент высчитать. Помогите ,пожалуйста.
93. Ali_q 1 03.10.22 12:19 Сейчас в теме
Кстати, заметил ошибку:

"Последующая - следующая от текущей группировки или детальной записи в наборе, возможно указать смещение «Следующая(2)»,
Текущая – текущая группировка или детальная запись"

Сначала пишется "Последующая" а потом уже уточняется что должно быть "Следующая". По моему должно быть так:

"Следующая- следующая от текущей группировки или детальной записи в наборе, возможно указать смещение «Следующая(2)»,
Текущая – текущая группировка или детальная запись"
95. user631943_norwegink 06.11.22 10:53 Сейчас в теме
Добрый день, подскажите, пожалуйста по запросу в СКД.
ERP. В статью бюджетирования нужно подтянуть значение страховых взносов для физ.лица из РН Исчисленные страховые взносы - т.е сложить все ресурсы взносов в ПФР, ФСС, ФОМС в одну итоговую сумму.
... при этом "смущает" требование к запросу, описанное на ИТС (https://its.1c.ru/db/erp25ltsdoc/bookmark/DataObtainingSetup/DataObtainingS­etup), а именно:
5. Обязательно требуется указание полей:
● СуммаРегл – сумма в валюте регламентированного учета;
● СуммаУпр – сумма в валюте управленческого учета;
● СуммаВВалюте – сумма в валюте. Это поле должно быть использовано в паре с полем Валюта или аналитикой, у которой есть реквизит Валюта.
А в РН Исчисленные страховые взносы нет таких ресурсов..
Спасибо!
97. user1274184 22.03.23 16:35 Сейчас в теме
Здравствуйте! Подскажите, пожалуйста, ВычислитьВыражениеСГруппировкойМассив возвращает массив значений. Как можно вывести только первое значение?
98. ids79 8291 24.03.23 15:48 Сейчас в теме
(97)На вскидку не подскажу. По-эксперементируйте с различными агрегатными функциями.
99. str_anton 01.06.23 15:46 Сейчас в теме
Есть вот такая формула вычислитьВыражение("Сумма(Лимит- ПланЗакупок)",,, "Первая", "Текущая"), которая рассчитывает нарастающий итог по группировкам. Можно ли как то установить в итог у родителя - последнюю рассчитанную строку детальных записей. В примере на скрине итоги считаются в разрезе группировок нарастающим итогом, можно ли как то вывести последнюю строку расчета детальных записей группировки в итог родителя?
Прикрепленные файлы:
108. ids79 8291 12.02.24 11:12 Сейчас в теме
(99)Попробуй для уровня группировка СтатьяБюджетиа установить вложенное условие.
Сделать что-то типа такого:
ВычислитьВыражение("(ВычислитьВыражение(""Сумма(Лимит- ПланЗакупок)"", ""Регистратор, СтатьяБюджета"",, ""Первая"", ""Текущая"")", "СтатьяБюджета",, "Последняя", "Последняя")
Оставьте свое сообщение