Количество строк в группировках универсального отчета

10.08.16

Разработка - Механизмы платформы 1С

Добавляем количество вложенных строк в группировки универсального отчета.

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

Добавляем в модуле отчета в самом конце процедуры СформироватьОтчет() код:

	УниверсальныйОтчет.СформироватьОтчет(ТабличныйДокумент,,, ЭтотОбъект);

	//ДополнитьГруппировкиКоличествомВложенныхСтрок()
	//{  
		ВысотаШапки = ПолучитьВысотуШапки(ТабличныйДокумент);
		
		Группировки = УниверсальныйОтчет.ПостроительОтчета.ИзмеренияСтроки;
		РезультатЗапроса = УниверсальныйОтчет.ПолучитьРезультат();
		
		// Стартуем рекурсивный обход таблицы
		Выборка = РезультатЗапроса.Выбрать(ОбходРезультатаЗапроса.ПоГруппировкам, Группировки[0].Имя);
		ДополнитьГруппировку(ТабличныйДокумент, Группировки, Выборка, 0, ВысотаШапки + 1, 0);
	//}
	
КонецПроцедуры // СформироватьОтчет()

И в конец модуля код самих функций:

////////////////////////////////////////////////////////////////////////////
// ФУНКЦИИ ДОПОЛНЕНИЯ ГРУППИРОВОК СТРОК

// Когда нет группировок колонок, то первая группировка строк двойная строка.
// Нужно сместиться на одну строку перед каждой группировкой первого уровня.
//
Функция ФиксСтрокПоГлубине(Глубина)
	
	Шаг = 0;
	
	Если Глубина = 0 И УниверсальныйОтчет.ПостроительОтчета.ИзмеренияКолонки.Количество() = 0 Тогда
		Шаг = 1;
	КонецЕсли;
	
	Возврат Шаг;
	
КонецФункции

// Дополняет ячейку количеством.
//
Процедура ВывестиКоличество(ТабличныйДокумент, НомерСтроки, Количество)
	
	Область = ТабличныйДокумент.Область(НомерСтроки, 2);
	Область.Текст = Область.Текст + "   (( " + Количество + " ))";
	
КонецПроцедуры	

// Рекурсивная процедура дополняет группировку количеством вложенных строк.
//
Процедура ДополнитьГруппировку(ТабличныйДокумент, Группировки, Выборка, Глубина, НомерСтроки, ПрошлоеКоличество)
	
	Если Глубина < Группировки.Количество() - 1 Тогда
		
		Пока Выборка.Следующий() Цикл
			
			// выбираем по следеющей группировке
			Выб = Выборка.Выбрать(ОбходРезультатаЗапроса.ПоГруппировкам, Группировки[Глубина + 1].Имя);
			
			// выводим количество в текущую строку
			Количество = Выб.Количество();
			ВывестиКоличество(ТабличныйДокумент, НомерСтроки, Количество);
			
			// шагаем на следующую и запускаемся рекурсивно
			НомерСтроки = НомерСтроки + 1;
			ДополнитьГруппировку(ТабличныйДокумент, Группировки, Выб, Глубина + 1, НомерСтроки, Количество);
			
			НомерСтроки = НомерСтроки + ФиксСтрокПоГлубине(Глубина);
			
		КонецЦикла;
		
	Иначе
		
		// находимся на дне дерева и нужно пропустить количество строк последнего уровня,
		// полученное на прошлом шаге.
		НомерСтроки = НомерСтроки + ПрошлоеКоличество;
		
	КонецЕсли;
	
КонецПроцедуры	

// Вычисляет высоту шапки отчета по области заголовка и группировкам.
//
Функция ПолучитьВысотуШапки(ТабличныйДокумент)
	
	ГруппКолонок = УниверсальныйОтчет.ПостроительОтчета.ИзмеренияКолонки.Количество();
	ГруппСтрок = УниверсальныйОтчет.ПостроительОтчета.ИзмеренияСтроки.Количество();
	
	Если ГруппКолонок > 0 Тогда
		ОбластьЗаголовка = ТабличныйДокумент.Области.Найти("Заголовок");
		ГруппСтрок = ?(ГруппСтрок < 3, 3, ГруппСтрок);
		ВысотаШапки = ОбластьЗаголовка.Низ + ГруппСтрок;
	Иначе
		ОбластьШапки = ТабличныйДокумент.Области.Найти("ШапкаТаблицы");
		ВысотаШапки = ОбластьШапки.Низ + 1;
	КонецЕсли;

	Возврат ВысотаШапки;
	
КонецФункции

// ФУНКЦИИ ДОПОЛНЕНИЯ ГРУППИРОВОК СТРОК
////////////////////////////////////////////////////////////////////////////

Значения подогнаны для УТ 10.3, если макет в вашей конфигурации немного отличается, то подогнать смещения не составит труда.

Вступайте в нашу телеграмм-группу Инфостарт

Универсальный отчет

Вы можете заказать платную адаптацию этой статьи под ваши задачи на «Бирже заказов».

  • Поиск от одного разработчика до ИТ-команд под проект.
  • Обмен любыми контактами разрешён.
  • 0% комиссии, допускаются расчёты напрямую.

См. также

Механизмы платформы 1С Программист Бесплатно (free)

Разберем 15 мифов о работе платформы «1С:Предприятие 8» – как распространенных, так и малоизвестных. Начнем с классики: «Код, написанный в одну строку, работает быстрее, чем многострочный». Так ли это на самом деле?

16.07.2025    31645    TitanLuchs    108    

149

Механизмы платформы 1С Работа с интерфейсом Программист Стажер 1С:Предприятие 8 Бесплатно (free)

Про ООП в 1С и о том, как сделать свой код более кратким и выразительным при помощи использования текучего интерфейса (fluent interface).

03.02.2025    17323    bayselonarrend    127    

68

Механизмы платформы 1С Программист 1С:Предприятие 8 Бесплатно (free)

В этой статье подробно рассматривается работа с JSON в XDTO в 1С:Предприятие. Вы узнаете, как сериализовать и десериализовать объекты XDTO в JSON, интегрировать 1С с веб-сервисами и API, а также корректно обрабатывать данные при обмене. Разбираются особенности работы с коллекциями, использование функций восстановления и частые ошибки при работе с JSON и XDTO.

30.01.2025    21190    user2122906    9    

66

Механизмы платформы 1С Файловый обмен (TXT, XML, DBF), FTP Программист 1С:Предприятие 8 Бесплатно (free)

Этот материал познакомит вас с механизмом XDTO (XML Data Transfer Objects) в 1С и научит эффективно использовать его возможности. Мы разберёмся, как работать с XML-схемами, создавать модели данных, манипулировать объектами XDTO, а также сериализовать и десериализовать их в XML. Вы узнаете, как использовать XDTO для интеграции с внешними системами, избегать типичных ошибок и оптимизировать код. К концу вы будете уверенно применять XDTO для решения сложных задач обмена данными и автоматизации процессов.

17.01.2025    37068    user2122906    12    

62

Механизмы платформы 1С WEB-интеграция Программист 1С:Предприятие 8 Бесплатно (free)

В платформе 8.3.27 появилась возможность использовать WebSocket-клиент. Давайте посмотрим, как это все устроено и чем оно нам полезно.

14.01.2025    32283    dsdred    106    

148

Механизмы платформы 1С Программист Стажер 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

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

23.06.2024    28334    bayselonarrend    22    

177

Механизмы платформы 1С Программист Стажер 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Пример использования «Сервисов интеграции» без подключения к Шине и без обменов.

13.03.2024    15373    dsdred    22    

86
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. jONES1979 14.02.17 11:35 Сейчас в теме
Очень любопытно! Большое спасибо!
2. timurboroda 24.11.25 03:03 Сейчас в теме
Количество строк в группировке отчета выводится с помощью пользовательского поля.

Формула: Количество(Различные Номенклатура)

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

Все!
Для отправки сообщения требуется регистрация/авторизация