1с скд вычисляемые поля функции. Примеры применения функции скд - вычислитьвыражение

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

Разберем первые три вкладки Схемы компоновки данных (1С СКД) – набор данных, связи набора данных и вычисляемые поля.

Набор данных в 1С СКД

Набор данных включает в себя возможность создания трёх объектов – запрос, объект и объединение, остановимся подробнее на каждом из них:

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

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

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

Условия, здесь мы выбираем те объекты, которые можно будет использовать в условиях в СКД.

Часть работы выполняется в схеме компоновки данных, часть программно, рассмотрим на простом примере:

Сначала создадим макет схема компоновки данных у документа и назовем СКД (например: 1С СКД), в нем создаем набор данных объект, далее заполняем поля, к примеру, имеем у документа табличную часть товары с реквизитами – номенклатура, количество и цена.

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

Создадим кнопку на форме документа, опишем механизм работы в управляемых формах:

&НаКлиенте

Процедура Печать()

НашОтчет = ПечатьНаСервере(); //вызываем функцию на сервере

НашОтчет.Показать(); //выводим сформированный отчет

КонецПроцедуры

&НаСервере

Функция ПечатьНаСервере()

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

//помещаем табличную часть Товары в структуру с наименованием ТоварыСКД так же, как мы указали в самой СКД имя объекта, содержащего данные

НаборДанных = Новый Структура;

НаборДанных.Вставить(“ТоварыСКД”, ОбъектДокумента.Товары);

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

НашМакет = ОбъектДокумента.ПолучитьМакет(“СКД”);

Настройки = НашМакет.НастройкиПоУмолчанию;

//создаем макет компоновки данных с нашими настройками

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

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

//выполняем компоновку данных с нашим набором данных

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

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

//формируем табличный документ и выводим в него наш отчет

ДокументОтчета = Новый ТабличныйДокумент;

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

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

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

Возврат ДокументОтчета;

КонецФункции

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

Объединение

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

Имеем таблицы:

При связи мы получим:

А при объединении:

Рассмотрим теперь заполнение колонок в наборах данных (некоторые пропустим, так как связаны с другими вкладками, к ним вернемся в будущих статьях):

- поле , указываем общее название реквизита;

­­- путь , указываем название реквизита, по которому будем к нему обращаться в СКД, к примеру, в Вычисляемых полях ;

- заголовок , указываем наименование реквизита, которое будет выводится в отчете;

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

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

- выражение, по которому вычисляется представление поле , удобно использовать, когда нам нужно изменить немного вывод реквизитов, к примеру, нам нужно, чтобы после имени номенклатуры выводился склад , на котором находится она, тогда заполним следующее: Номенклатура + “ находится на складе ” + Склад. Повторюсь, что обращение реквизитам осуществляется через название, указанное в колонке путь;

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

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

- доступные значения , работает лишь при заполненном типе значения , открываем форму заполнения и в колонке Значение указываем элемент, который нужно изменить, согласно типу, это может быть предопределенные объекты или у числовых, к примеру, реквизитов простые значения, в представлении указываем, на что нам нужно поменять, пример булевского типа:

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

Связи набора данных в 1С СКД

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

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

  1. нарастающий итог в группировке;
  2. нарастающий итог в кросс-таблице;
  3. получение предыдущего значения;
  4. вывод ТЧ в одной строке.

1. Получение показателя нарастающим итогом

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

Если количество товара нарастающим итогом требуется получать на уровне детальных записей, то функцию ВычислитьВыражение задаем для вычисляемого поля на вкладке "Вычисляемые поля" (см. рисунок 3).
В зависимости от уровня получения нарастающего итога, создаем группировку (см. рисунок 4): на уровне ресурсов - группировку по товарам, на уровне ДЗ - группировку детальных записей.
Рисунок 4. Группировки отчета с нарастающим итогом

2. Получение значения показателя из предыдущей строки

Получим курс валюты на дату и предыдущую дату. Для этого создаем вычисляемое поле и в поле выражение пишем следующее выражение (см. рисунок 5):
ВычислитьВыражение("Курс", "Предыдущая", "Предыдущая")
которое будет брать предыдущее значение курса валюты для текущей строки, последний параметр функции ограничивает получение данных.
Так как работаем на уровне детальных записей, сразу переходим к вкладке "Настройки" и создаем группировку - детальные записи.

3. Получение показателя нарастающим итогом в кросс-таблице

Получим количество товара нарастающим итогом в разрезе периода. Для этого создаем вычисляемое поле (см. рисунок 1). На вкладке "Ресурсы" для вычисляемого поля укажем следующее выражение (см. рисунок 6):
ВычислитьВыражение("Сумма(КоличествоОборот)", "Период", "Первая", "Текущая")
которое на уровне группировки будет вычислять количество товара в промежутке от первой строки до текущей в разрезе периода по каждой номенклатуре.
На вкладке "Настройки" создаем таблицу с группировкой по номенклатуре в строке и группировкой по периоду в колонке (см. рисунок 7).

4. Вывод данных табличной части в одну строку

Способы вывода данных табличной части в одну строку, включая способ с использованием функции ВычислитьВыражение, рассмотрен в статье
  • 1С-Битрикс
  • Одна из самых важных областей бизнес-софта – это отчетность. От того, насколько легко настроить под меняющиеся потребности бизнеса (и законодательства) существующий отчет или сделать новый, может зависеть (причем не в переносном смысле!) судьба бизнеса, будь то отчет для налоговой инспекции или диаграмма зависимости спроса на товары от сезона и других факторов. Мощная и гибкая система отчетности, позволяющая легко извлечь из системы нужные данные, представить их в доступном для понимания виде, позволяющая конечному пользователю перенастроить стандартный отчет так, чтобы увидеть данные в новом свете – это идеал, к которому должна стремиться каждая бизнес-система.

    В платформе «1С:Предприятие» за построение отчётов отвечает механизм под названием «Система компоновки данных» (сокращенно СКД). В этой статье мы постараемся дать краткое описание идеи и архитектуры механизма СКД и его возможностей.


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

    Немного истории

    В самой первой версии платформы «1С:Предприятие 8», версии 8.0, отчеты делались так:
    1. Писался один или несколько запросов на языке запросов 1С (SQL-подобный язык, подробнее о нем ниже).
    2. Писался код, который переносил результаты выполненных запросов в табличный документ или в диаграмму. Код также мог делать работу, которую в запросе сделать невозможно – например, вычислял значения, используя встроенный язык 1С.
    Подход прямолинейный, но не самый удобный – визуальных настроек минимум, все приходится программировать «врукопашную». А один из козырей на тот момент совсем новой платформы «1С:Предприятие 8» - это минимизация в прикладном решении объема кода, который нужно писать вручную, в частности, за счет визуального проектирования. Логично было бы пойти этим же путем и в механизме построения отчетов. Что и было сделано путем разработки нового механизма - Системы Компоновки Данных.

    Одной из идей, легших в основу СКД, была гибкость и настраиваемость отчетов, причем доступная как разработчику, так и конечному пользователю. В идеале хотелось бы дать доступ конечному пользователю к тому же набору инструментов для дизайна отчета, что и разработчику. Логично было бы сделать единый набор инструментов, доступный всем. Ну а раз инструменты предполагают участие конечного пользователя – значит, нужно использование программирования в них убрать до минимума (лучше всего – устранить совсем), и по максимуму использовать визуальные настройки.

    Постановка задачи

    Задача перед командой разработки стояла такая – сделать систему создания отчетов, основанную не на алгоритмическом (т.е. через написание кода), а на декларативном подходе к созданию отчетов. И мы считаем, что задачу успешно решили. По нашему опыту, около 80% требуемой отчетности может быть реализована с помощью СКД без единой строчки кода (за исключением написания формул вычисляемых полей), по большей части - через визуальные настройки.
    Разработка первой версии СКД заняла около 5 человеко-лет.

    Два языка

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

    Язык запросов

    Язык запросов основан на SQL и легко осваивается знающими SQL. Пример запроса:

    Легко видеть аналоги стандартных для SQL-запроса секций - SELECT, FROM, GROUP BY, ORDER BY.

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

    • Обращение к полям через точку. Если поля какой-либо таблицы имеют ссылочный тип (хранят ссылки на объекты другой таблицы), разработчик может в тексте запроса ссылаться на них через ".", при этом количество уровней вложенности таких ссылок система не ограничивает (например, ЗаказКлиента.Соглашение.Организация.Телефон).
    • Многомерное и многоуровневое формирование итогов. Итоги и подитоги формируются с учетом группировки и иерархии, обход уровней может выполняться в произвольном порядке с подведением подитогов, обеспечивается корректное построение итогов по временным измерениям.
    • Поддержка виртуальных таблиц. Виртуальные таблицы, предоставляемые системой, позволяют получить практически готовые данные для большинства прикладных задач без необходимости составления сложных запросов. Так, виртуальная таблица может предоставить данные по остаткам товаров в разрезе периодов на какой-то момент времени. При этом виртуальные таблицы максимально используют хранимую информацию, например, ранее рассчитанные итоги и т.д.
    • Временные таблицы. Язык запросов позволяет использовать в запросах временные таблицы. С их помощью можно повысить производительность запросов, в некоторых случаях снизить количество блокировок и сделать текст запроса более легким для восприятия.
    • Пакетные запросы. Для более удобной работы с временными таблицами в языке запросов поддерживается работа с пакетными запросами - таким образом, создание временной таблицы и ее использование помещаются в один запрос. Пакетный запрос представляет собой последовательность запросов, разделенных точкой с запятой (";"). Запросы в пакете исполняются один за другим. Результатом выполнения пакетного запроса, в зависимости от используемого метода, будет являться либо результат, возвращаемый последним запросом пакета, либо массив результатов всех запросов пакета в той последовательности, в которой следуют запросы в пакете.
    • Получение представлений ссылочных полей. Каждая объектная таблица (в которой хранится справочник или документ) имеет виртуальное поле - «Представление». Это поле содержит текстовое представление объекта и облегчает работу создателя отчетов. Так, для документа это поле содержит всю ключевую информацию - название типа документа, его номер и дату (например, «Продажа 000000003 от 06.07.2017 17:49:14»), избавляя разработчика от написания вычисляемого поля.
    • и др.
    Механизм запросов автоматически модифицирует запрос с учетом ролей , к которым принадлежит пользователь, от имени которого выполняется запрос (т.е. пользователь увидит только те данные, которые имеет право видеть) и функциональных опций (т.е. в соответствии с настроенной в прикладном решении функциональностью).

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

    Например:

    • ВЫБРАТЬ. В этом предложении описываются поля, которые пользователь сможет выбирать для вывода. После данного ключевого слова через запятую перечисляются псевдонимы полей из основного списка выборки запроса, которые будут доступными для настройки. Пример: {ВЫБРАТЬ Номенклатура, Склад}
    • ГДЕ. Описываются поля, на которые пользователь сможет накладывать отбор. В данном предложении используются поля таблиц. Использование псевдонимов полей списка выборки недопустимо. Каждая часть объединения может содержать собственный элемент ГДЕ. Примеры: {ГДЕ Номенклатура.*, Склад }, {ГДЕ Документ.Дата >= &ДатаНачала, Документ.Дата <= &ДатаКонца}
    • и др.
    Пример использования расширений:

    Язык выражений компоновки данных

    Язык выражений компоновки данных предназначен для записи выражений, используемых, в частности, для описания выражений пользовательских полей. СКД позволяет определять в отчете пользовательские поля, используя либо собственные выражения, либо наборы вариантов с условиями их выбора (аналог CASE в SQL). Пользовательские поля являются аналогом вычисляемых полей. Они могут задаваться как в конфигураторе, так и в режиме «1С:Предприятие», но в выражениях пользовательских полей нельзя использовать функции общих модулей. Поэтому пользовательские поля предназначены скорее для пользователя, чем для разработчика.

    Пример:

    Процесс создания отчета на СКД

    При создании отчета нам нужно создать макет, определяющий, как данные будут отображаться в отчете. Можно создать макет, базирующийся на схеме компоновки данных. Схема компоновки данных описывает суть данных, которые предоставляются отчету (откуда получать данные и как можно управлять их компоновкой). Схема компоновки данных представляет собой базу, на основе которой могут быть сформированы всевозможные отчеты. Схема компоновки данных может содержать:
    • текст запроса с инструкциями системы компоновки данных;
    • описание нескольких наборов данных;
    • подробное описание доступных полей;
    • описание связей между несколькими наборами данных;
    • описание параметров получения данных;
    • описание макетов полей и группировок;
    • и др.

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

    Итогом запуска конструктора запросов будет текст запроса (на языке запросов «1С:Предприятия»). Этот текст можно при необходимости скорректировать вручную:

    Наборов данных в схеме компоновки данных может быть несколько, наборы данных могут быть связаны в макете произвольным образом, могут быть добавлены вычисляемые поля, заданы параметры отчета и т.п. Стоит упомянуть интересную особенность работы механизма запросов в 1С:Предприятии. Запросы в конечном итоге транслируются в диалект SQL, специфичный для СУБД, с которой непосредственно работает приложение. Мы вообще стараемся задействовать возможности серверов СУБД по максимуму (нас ограничивает то, что мы используем только те возможности, которые есть одновременно во всех поддерживаемых платформой «1С:Предприятие» СУБД – MS SQL, Oracle, IBM DB2, PostgreSQL). Таким образом, на уровне запроса в вычисляемых полях мы можем использовать только те функции, которые транслируются в SQL.

    А вот на уровне схемы компоновки данных мы уже можем добавлять пользовательские поля и использовать в них функции на встроенном языке разработки 1С (в том числе и написанные нами), что сильно расширяет возможности отчетов. Технически это выглядит так – всё, что можно транслировать в SQL, транслируется в SQL, запрос выполняется на уровне СУБД, результаты запроса помещаются в память сервера приложений 1С и СКД вычисляет для каждой записи значения вычисляемых полей, чьи формулы написаны на языке 1С.


    Добавление пользовательских полей

    В отчет можно добавить произвольное количество таблиц и диаграмм:


    Дизайнер отчетов


    Отчет во время выполнения

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

    Коротко описать процесс построения и формирования отчета можно так:

    • Разработчик в design time с помощью дизайнера (или в runtime с помощью кода) определяет схему компоновки данных:
      • Текст запроса/запросов
      • Описание вычисляемых полей
      • Связи между запросами (если их несколько)
      • Параметры отчета
      • Настройки по умолчанию
      • И т.д.
    • Вышеописанные настройки сохраняются в макете
    • Пользователь открывает отчет
      • Возможно, делает дополнительные настройки (например, меняет значения параметров)
      • Нажимает кнопку «Сформировать»
    • Настройки пользователя применяются к схеме компоновки данных, определенной разработчиком.
    • Формируется промежуточный макет компоновки данных, содержащий в себе инструкции, откуда получать данные. В частности, корректируются запросы, заданные в макете. Так, из запроса удаляются поля, которые не используются в отчете (это делается с целью минимизировать объем получаемых данных). В запрос добавляются все поля, участвующие в формулах вычисляемых полей.
    • В дело включается процессор компоновки данных. Процессор компоновки выполняет запросы, осуществляет связь наборов данных, рассчитывает значения вычисляемых полей и ресурсов, выполняет группировку. Словом, делает все расчеты, которые не были выполнены на уровне СУБД.
    • Процессор вывода данных запускает запрос на исполнение и выводит полученные данные в табличный документ, диаграмму и т.п.


    Процесс формирования отчета механизмом СКД

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

    Пользовательские настройки

    Весь инструментарий СКД доступен как разработчику, так и конечному пользователю. Но практика показала, что конечного пользователя часто пугает обилие возможностей инструмента. Тем более что в большинстве случаев вся мощь настроек конечному пользователю и не нужна – ему достаточно иметь быстрый доступ к настройке одного-двух параметров отчета (например, периода и контрагента). Начиная с определенной версии платформы у разработчика отчета появилась возможность отметить, какие настройки отчета доступны пользователю. Делается это с помощью флажка «Включать в пользовательские настройки». Также у настроек отчета появился флаг «Режим отображения», принимающий одно из трех значений:
    • Быстрый доступ. Настройка будет выведена непосредственно в верхнюю часть окна отчета.
    • Обычный. Настройка будет доступна через кнопку «Настройки».
    • Недоступный. Настройка будет недоступна конечному пользователю.


    Режим отображения настройки в design time


    Отображение настройки в режиме «Быстрый доступ» во время выполнения (под кнопкой «Сформировать»)

    Планы развития

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

    Язык выражений системы компоновки данных

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

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

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

    Литералы

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

    • Строка;
    • Число;
    • Дата;
    • Булево.

    Строка

    Строковый литерал записывается в символах «”», например:

    “Строковой литерал“

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

    Например:

    “Литерал ““в кавычках“““

    Число

    Число записывается без пробелов, в десятичном формате. Дробная часть отделяется при помощи символа «.». Например:

    10.5 200

    Дата

    Литерал типа дата записывается при помощи ключевого литерала ДАТАВРЕМЯ (DATETIME). После данного ключевого слова, в скобках, через запятую перечисляются год, месяц, день, часы, минуты, секунды. Указание времени не обязательно.

    Например:

    ДАТАВРЕМЯ(1975, 1, 06) – Шестое января 1975 года ДАТАВРЕМЯ(2006, 12, 2, 23, 56, 57) – Второе декабря 2006 года, 23 часа 56 минут 57 секундода, 23 часа 56 минут 57 секунд

    Булево

    Булевы значения могут быть записаны при помощи литералов Истина (True), Ложь (False).

    Значение

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

    Значение(ВидСчета. Активный)

    Операции над числами

    Унарный –

    Данная операция предназначена для изменения знака числа на обратный. Например:

    Продажи.Количество

    Унарный +

    Данная операция не выполняет над числом никаких действий. Например:

    Продажи.Количество

    Бинарный -

    Данная операция предназначена для вычисления разности двух чисел. Например:

    ОстаткиИОбороты.НачальныйОстаток – ОстаткиИОбороты.КонечныйОстаток ОстаткиИОбороты.НачальныйОстаток - 100 400 – 357

    Бинарный +

    Данная операция предназначена для вычисления суммы двух чисел. Например:

    ОстаткиИОбороты.НачальныйОстаток + ОстаткиИОбороты.Оборот ОстаткиИОбороты.НачальныйОстаток + 100 400 + 357

    Произведение

    Данная операция предназначена для вычисления произведения двух чисел. Например:

    Номенклатура.Цена * 1.2 2 * 3.14

    Деление

    Данная операция предназначена для получения результата деления одного операнда на другой. Например:

    Номенклатура.Цена / 1.2 2 / 3.14

    Остаток от деления

    Данная операция предназначена для получения остатка от деления одного операнда на другой. Например:

    Номенклатура.Цена % 1.2 2 % 3.14

    Операции над строками

    Конкатенация (Бинарный +)

    Данная операция предназначена для конкатенации двух строк. Например:

    Номенклатура.Артикул + “: ”+ Номенклатура.Наименование

    Подобно

    Данная операция проверяет соответствие строки переданному шаблону.

    Значением оператора ПОДОБНО является ИСТИНА, если значение <Выражения> удовлетворяет шаблону, и ЛОЖЬ в противном случае.

    Следующие символы в <Строке_шаблона> имеют смысл, отличный от просто очередного символа строки:

    • % - процент: последовательность, содержащая ноль и более произвольных символов;
    • _ - подчеркивание: один произвольный символ;
    • […] - один или несколько символов в квадратных скобках: один символ, любой из перечисленных внутри квадратных скобок. В перечислении могут встречаться диапазоны, например a-z, означающие произвольный символ, входящий в диапазон, включая концы диапазона;
    • [^…] - в квадратных скобках значок отрицания, за которым следует один или несколько символов: любой символ, кроме тех, которые перечислены следом за значком отрицания;

    Любой другой символ означает сам себя и не несет никакой дополнительной нагрузки. Если в качестве самого себя необходимо записать один из перечисленных символов, то ему должен предшествовать <Спецсимвол>, указанный после ключевого слова СПЕЦСИМВОЛ (ESCAPE).

    Например, шаблон

    “%АБВ[абвг]\_абв%” СПЕЦСИМВОЛ “\”

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

    Операции сравнения

    Равно

    Данная операция предназначена для сравнения двух операндов на равенство. Например:

    Продажи.Контрагент = Продажи.НоменклатураОсновнойПоставщик

    Не равно

    Данная операция предназначена для сравнения двух операндов на неравенство. Например:

    Продажи.Контрагент <> Продажи.НоменклатураОсновнойПоставщик

    Меньше

    Данная операция предназначена для проверки того, что первый операнд меньше второго. Например:

    ПродажиТекщие.Сумма < ПродажиПрошлые.Сумма

    Больше

    Данная операция предназначена для проверки того, что первый операнд больше второго. Например:

    ПродажиТекщие.Сумма > ПродажиПрошлые.Сумма

    Меньше или равно

    Данная операция предназначена для проверки того, что первый операнд меньше либо равен второму. Например:

    ПродажиТекщие.Сумма <= ПродажиПрошлые.Сумма

    Больше или равно

    Данная операция предназначена для проверки того, что первый операнд больше либо равен второму. Например:

    ПродажиТекщие.Сумма >= ПродажиПрошлые.Сумма

    Операция В

    Данная операция осуществляет проверку наличия значения в переданном списке значений. Результатом операции будет Истина, в случае, если значение найдено, или Ложь - в противном случае. Например:

    Номенклатура В (&Товар1, &Товар2)

    Операция проверки наличия значения в наборе данных

    Операция осуществляет проверку наличия значения в указанном наборе данных. Набор данных для проверки должен содержать одно поле. Например:

    Продажи.Контрагент В Контрагенты

    Операция проверки значения на NULL

    Данная операция возвращает значение Истина в случае, если значение является значением NULL. Например:

    Продажи.Контрагент ЕСТЬ NULL

    Операция проверки значения на неравенство NULL

    Данная операция возвращает значение Истина в случае, если значение не является значением NULL. Например:

    Продажи.Контрагент ЕСТЬ НЕ NULL

    Логические операции

    Логические операции принимают в качестве операндов выражения, имеющие тип Булево.

    Операция НЕ

    Операция НЕ возвращает значение Истина в случае, если ее операнд имеет значение Ложь, и значение Ложь в случае, если ее операнд имеет значение Истина. Например:

    НЕ Документ.Грузополучатель = Документ.Грузоотправитель

    Операция И

    Операция И возвращает значение Истина в случае, если оба операнда имеют значение Истина, и значение Ложь в случае, если один из операндов имеет значение Ложь. Например:

    Документ.Грузополучатель = Документ.Грузоотправитель И Документ.Грузополучатель = &Контрагент

    Операция ИЛИ

    Операция ИЛИ возвращает значение Истина в случае, если один из операндов имеет значение Истина, и Ложь в случае, если оба операнда имеют значение Ложь. Например:

    Документ.Грузополучатель = Документ.Грузоотправитель ИЛИ Документ.Грузополучатель = &Контрагент

    Агрегатные функции

    Агрегатные функции осуществляют некоторое действие над набором данных.

    Сумма

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

    Сумма(Продажи.СуммаОборот)

    Количество

    Функция Количество рассчитывает количество значений отличных от значения NULL. Например:

    Количество(Продажи.Контрагент)

    Количество различных

    Эта функция рассчитывает количество различных значений. Например:

    Количество(Различные Продажи.Контрагент)

    Максимум

    Функция получает максимальное значение. Например:

    Максимум(Остатки.Количество)

    Минимум

    Функция получает минимальное значение. Например:

    Минимум(Остатки.Количество)

    Среднее

    Функция получает среднее значение для значений, отличных от NULL. Например:

    Среднее(Остатки.Количество)

    Другие операции

    Операция ВЫБОР

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

    Выбор Когда Сумма > 1000 Тогда Сумма Иначе 0 Конец

    Правила сравнения двух значений

    Если типы сравниваемых значений отличаются друг от друга, то отношения между значениями определяются на основании приоритета типов:

    • NULL (самый низший);
    • Булево;
    • Число;
    • Дата;
    • Строка;
    • Ссылочные типы

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

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

    • у типа Булево значение ИСТИНА больше значения ЛОЖЬ;
    • у типа Число обычные правила сравнения для чисел;
    • у типа Дата более ранние даты меньше более поздних;
    • у типа Строка - сравнения строк в соответствии с установленными национальными особенностями базы данных;
    • ссылочные типы сравниваются на основе своих значений (номера записи и т. п.).

    Работа со значением NULL

    Любая операция, в которой значение одного из операндов NULL, будет давать результат NULL.

    Есть исключения:

    • операция И будут возвращать NULL только в случае, если ни один из операндов не имеет значение Ложь;
    • операция ИЛИ будет возвращать NULL только в случае, если ни один из операндов не имеет значение Истина.

    Приоритеты операций

    Операции имеют следующие приоритеты (первая строка имеет низший приоритет):

    • В, ЕСТЬ NULL, ЕСТЬ НЕ NULL;
    • =, <>, <=, <, >=, >;
    • Бинарный +, Бинарный – ;
    • *, /, %;
    • Унарный +, Унарный -.

    Функции языка выражений системы компоновки данных

    Вычислить

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

    • Выражение. Тип Строка. Содержит вычисляемое выражение;
    • Группировка. Тип Строка. Содержит имя группировки, в контексте которой необходимо вычислить выражение. В случае если в качестве имени группировки используется пустая строка, вычисление будет выполнено в контексте текущей группировки. В случае если в качестве имени группировки будет использована строка ОбщийИтог, вычисление будет выполнено в контексте общего итога. В остальных случаях вычисление будет выполняться в контексте родительской группировки с таким именем. Например:
    Сумма(Продажи.СуммаОборот) / Вычислить("Сумма(Продажи.СуммаОборот)", "ОбщийИтог")

    В данном примере в результате получится отношение суммы по полю "Продажи.СуммаОборот" записи группировки к сумме того же поля во всей компоновке.

    Уровень

    Функция предназначена для получения текущего уровня записи.

    Уровень()

    НомерПоПорядку

    Получить следующий порядковый номер.

    НомерПоПорядку()

    НомерПоПорядкуВГруппировке

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

    НомерПоПорядкуВГруппировке()

    Формат

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

    Форматная строка задается в соответствии с форматной строкой 1С:Предприятие.

    Параметры:

    • Значение;
    • Форматная строка.

    Формат(РасходныеНакладные.СуммаДок, "ЧДЦ=2")

    НачалоПериода

    Параметры:

      • Минута;
      • День;
      • Неделя;
      • Месяц;
      • Квартал;
      • Декада;
      • Полугодие.

    НачалоПериода(ДатаВремя(2002, 10, 12, 10, 15, 34), "Месяц")

    Результат:

    01.10.2002 0:00:00

    КонецПериода

    Функция предназначена для выделения определенной даты из заданной даты.

    Параметры:

    • Дата. Тип Дата. Заданная дата;
    • Тип периода. Тип Строка. Содержит одно из значений:
      • Минута;
      • День;
      • Неделя;
      • Месяц;
      • Квартал;
      • Декада;
      • Полугодие.

    КонецПериода(ДатаВремя(2002, 10, 12, 10, 15, 34), "Неделя")

    Результат:

    13.10.2002 23:59:59

    ДобавитьКДате

    Функция предназначена для прибавления к дате некоторой величины.

    Параметры:

    • Тип увеличения. Тип Строка. Содержит одно из значений:
      • Минута;
      • День;
      • Неделя;
      • Месяц;
      • Квартал;
      • Декада;
      • Полугодие.
    • Величина – на сколько необходимо увеличить дату. Тип Число. Дробная часть игнорируется.

    ДобавитьКДате(ДатаВремя(2002, 10, 12, 10, 15, 34), "Месяц", 1)

    Результат:

    12.11.2002 10:15:34

    РазностьДат

    Функция предназначена для получения разницы между двумя датами.

    Параметры:

    • Выражение. Тип Дата. Исходная дата;
    • Выражение. Тип Дата. Вычитаемая дата;
    • Тип разности. Тип Строка. Содержит одно из значений:
      • Секунда;
      • Минута;
      • День;
      • Месяц;
      • Квартал;

    РАЗНОСТЬДАТ(ДАТАВРЕМЯ(2002, 10, 12, 10, 15, 34), ДАТАВРЕМЯ(2002, 10, 14, 9, 18, 06), "ДЕНЬ")

    Результат:

    Подстрока

    Данная функция предназначена для выделения подстроки из строки.

    Параметры:

    • Строка. Тип Строка. Строка, из которой выделяют подстроку;
    • Позиция. Тип Число. Позиция символа, с которого начинается выделяемая из строки подстрока;
    • Длина. Тип Число. Длина выделяемой подстроки.

    ПОДСТРОКА(Контрагенты.Адрес, 1, 4)

    ДлинаСтроки

    Функция предназначена для определения длины строки.

    Параметр:

    • Строка. Тип Строка. Строка, длину которой определяют.

    Строка(Контрагенты.Адрес)

    Год

    Данная функция предназначена для выделения года из значения типа Дата.

    Параметр:

    • Дата. Тип Дата. Дата, по которой определяют год.

    ГОД(РасхНакл.Дата)

    Квартал

    Данная функция предназначена для выделения номера квартала из значения типа Дата. Номер квартала в норме находится в диапазоне от 1 до 4.

    Параметр

    • Дата. Тип Дата. Дата, по которой определяют квартал
    КВАРТАЛ(РасхНакл.Дата)

    Месяц

    Данная функция предназначена для выделения номера месяца из значения типа Дата. Номер месяца в норме находится в диапа-зоне от 1 до 12.

    • Дата. Тип Дата. Дата, по которой определяют месяц.
    МЕСЯЦ(РасхНакл.Дата)

    ДеньГода

    Данная функция предназначена для получения дня года из значения типа Дата. День года в норме находится в диапазоне от 1 до 365(366).

    • Дата. Тип Дата. Дата, по которой определяют день года.
    ДЕНЬГОДА(РасхНакл.Дата)

    День

    Данная функция предназначена для получения дня месяца из значения типа Дата. День месяца в норме находится в диапазоне от 1 до 31.

    • Дата. Тип Дата. Дата, по которой определяют дня месяца.
    ДЕНЬ(РасхНакл.Дата)

    Неделя

    Данная функция предназначена для получения номера недели года из значения типа Дата. Недели года нумеруются, начиная с 1.

    • Дата. Тип Дата. Дата, по которой определяют номера недели.
    НЕДЕЛЯ(РасхНакл.Дата)

    ДеньНедели

    Данная функция предназначена для получения дня недели из значения типа Дата. День недели в норме находится в диапазоне от 1 (понедельник) до 7(воскресенье).

    • Дата. Тип Дата. Дата, по которой определяют день недели.
    ДЕНЬНЕДЕЛИ(РасхНакл.Дата)

    Час

    Данная функция предназначена для получения часа суток из значения типа Дата. Час суток находится в диапазоне от 0 до 23.

    • Дата. Тип Дата. Дата, по которой определяют час суток.
    ЧАС(РасхНакл.Дата)

    Минута

    Данная функция предназначена для получения минуты часа из значения типа Дата. Минута часа находится в диапазоне от 0 до 59.

    • Дата. Тип Дата. Дата, по которой определяют минута часа.
    МИНУТА(РасхНакл.Дата)

    Секунда

    Данная функция предназначена для получения секунды минуты из значения типа Дата. Секунда минуты находится в диапазоне от 0 до 59.

    • Дата. Тип Дата. Дата, по которой определяют секунды минуты.
    СЕКУНДА(РасхНакл.Дата)

    Выразить

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

    Параметры:

    • Преобразуемое выражение;
    • Указание типа. Тип Строка. Содержит строку типа. Например, "Число", "Строка" и т.п. Кроме примитивных типов данная строка может содержать имя таблицы. В этом случае будет осуществлена попытка выразить к ссылке на указанную таблицу.

    Выразить(Данные.Реквизит1, "Число(10,3)")

    ЕстьNull

    Данная функция возвращает значение второго параметра в случае, если значение первого параметра NULL.

    В противном случае будет возвращено значение первого параметра.

    ЕстьNULL(Сумма(Продажи.СуммаОборот), 0)

    Функции общих модулей

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

    В данном примере будет осуществлен вызов функции "СокращенноеНаименование" из общего модуля конфигурации.

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

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

    Войдите на сайт как ученик

    Войдите как ученик, чтобы получить доступ к материалам школы

    Система компоновки данных 1С 8.3 для начинающих: считаем итоги (ресурсы)

    Целью этого урока будет:

    • Написать отчёт, который выводит список продуктов (справочник Еда), их калорийность и вкус.
    • Сделать группировку продуктов по их цвету.
    • Познакомиться с возможностью подведения итогов (ресурсы) и вычисляемыми полями.

    Создаём новый отчёт

    Как и на предыдущих уроках открываем базу "Гастроном " в конфигураторе и создаём новый отчёт через меню "Файл "->"Новый... ":

    Вид документа - внешний отчёт :

    В форме настройки отчёта пишем имя "Урок3 " и нажимаем кнопку "Открыть схему компоновки данных ":

    Оставляем имя схемы по умолчанию и нажимаем кнопку "Готово ":

    Добавляем запрос через конструктор

    На закладке "Набор данных " нажимаем зелёный плюсик и выбираем пункт "Добавить набор данных - запрос ":

    Вместо того, чтобы писать текст запроса вручную, вновь запускаем конструктор запроса :

    На вкладке "Таблицы " перетягиваем таблицу "Еда " из первой колонки во вторую:

    Выбираем из таблицы "Еда " поля, которые будем запрашивать. Для этого перетаскиваем поля "Наименование ", "Вкус ", "Цвет " и "Калорийность " из второй колонки в третью:

    Получилось вот так:

    Нажимаем кнопку "ОК " - текст запроса сформировался автоматически:

    Формируем настройки представления отчёта

    Переходим на закладку "Настройки " и нажимаем на волшебную палочку , чтобы вызвать конструктор настроек :

    Выбираем вид отчета "Список ..." и нажимаем кнопку "Далее ":

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

    Перетаскиваем из левой колонки в правую поле "Цвет " - по нему будет происходить группировка строк в отчёте. Нажимаем "ОК ":

    А вот и результат работы конструктора. Иерархия нашего отчёта:

    • отчёт в целом
    • группировка "Цвет"
    • детальные записи - строки с названиями еды

    Сохраним отчёт (кнопка дискета ) и не закрывая конфигуратора тут же откроем его в режиме пользователя. Получилось вот так:

    Меняем порядок колонок

    Но давайте поменяем порядок колонок (стрелки вверх-вниз), чтобы он был таким как на рисунке ниже:

    Сохраним отчёт и вновь откроем в режиме пользователя:

    Отлично, так гораздо лучше.

    Подводим итог (сумму) по калорийности

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

    Для этого существует механизм вычисления ресурсов.

    Переходим на вкладку "Ресурсы " и перетаскиваем поле "Калорийность " (мы же по нему собираемся итог подводить) из левой колонки в правую.

    При этом в поле выражение выбираем из выпадающего списка "Сумма(Калорийность) ", так как итогом будет являться сумма всех входящих в итог элементов:

    Сохраняем и формируем отчёт:

    У нас появились итоги по каждой из групп и по отчёту в целом.

    Подводим итог (среднее) по калорийности

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

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

    Чтобы завести такое "виртуальное" поле воспользуемся механизмом вычисляемых полей .

    Переходим на закладку "Вычисляемые поля " и нажимаем зелёный плюсик:

    В колонке "Путь к данным " пишем имя нового поля (слитно , без пробелов ). Пусть оно будет называться "СредняяКалорийность ", а в колонке "Выражение " пишем имя уже существующего поля, на основании которого будет рассчитываться новое поле. Пишем туда "Калорийность ". Колонка "Заголовок " заполнится автоматически.

    Мы добавили новое поле ("СредняяКалорийность "), но в отчёте оно само по себе не появится - нужно или вновь вызывать конструктор настроек ("волшебная палочка") или добавить это поле вручную .

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

    Получилось вот так:

    Сохраняем и формируем отчет:

    Поле появилось и мы видим, что его значениями являются значения поля "Калорийность". Отлично!

    Для этого вновь воспользуемся уже знакомым нам механизмом ресурсов (подведение итогов). Переходим на закладку "Ресурсы " и перетаскиваем поле "СредняяКалорийность " из левой колонки в правую:

    При этом в колонке "Выражение " выбираем "Среднее(СредняяКалорийность) ":

    Сохраняем и формируем отчёт:

    Видим, что по группам, то есть по каждому цвету, и по отчёту в целом совершенно верно посчиталось среднее значение. Но присутствуют лишние записи по отдельным продуктам (не по группам), которые хотелось бы убрать из отчёта.

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

    Исправим ошибку. Для этого вернёмся на закладку "Настройки ", выберем "Детальные записи " сначала сверху (шаг 2), а затем "Детальные записи " снизу (шаг 3), перейдём на закладку "Выбранные поля " и увидим в её правой колонке элемент "Авто ".

    Элемент "Авто " - это не одно поле. Это несколько полей, которые попадают сюда автоматически на основании вышестоящих настроек.

    Чтобы увидеть, что это за поля - нажмём на элемент "Авто " правой кнопкой и выберем пункт "Развернуть ":

    Элемент "Авто " раскрылся в следующие поля:

    А вот и наше поле "СредняяКалорийность ", которое попало сюда из пункта "Отчет ", когда мы его туда перетаскивали. Просто снимем галку рядом с этим полем, чтобы убрать его вывода.

    Что еще почитать