Нарезка графика ломтями

Публикация № 1639182 09.04.22

Приемы и методы разработки - СКД

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

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

 

 

Вид, честно говоря, не очень. Как-то тесновато графику в рамках, отведенных платформой.
Не скажу, что я большой мастер рисования графиков в 1С. Как раз наоборот. И наверняка внешний вид можно улучшить, если залезть в код и сделать все самому. Но что-то не хочется мне туда лезть.
Ладно, что тут можно сделать из простого? А добавлю-ка я группировку диаграмм по годам:

 

 

И, соответственно, строчку в запрос:

    ГОД(ВТОтчет.Месяц) КАК Год

Здесь Месяц – это дата начала месяца, так что все нормально.

 

 

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

 

 

И тут пришла в голову идея – почему бы не нарезать график не по календарным годам, а просто по периодам в год, но только отсчитывать их назад от текущего момента?
Сейчас на дворе апрель – вот пусть и режет на куски с мая по апрель.
Пришлось еще сильнее удлинить запрос. Только не спрашивайте, зачем столько временных таблиц. Причина скрыта за многоточием.

…
	ГОД(ВТОтчет.Месяц) КАК Год
ПОМЕСТИТЬ ВТсГодом
ИЗ
	ВТОтчет КАК ВТОтчет
;

////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ
	ВТсГодом.Месяц,
	ВТсГодом.Приход,
	ВТсГодом.Расход,
	ВТсГодом.Год,
	ВЫБОР
		КОГДА МЕСЯЦ(ВТсГодом.Месяц) > ВЗМесяц.ПоследнийМесяц
			ТОГДА ВТсГодом.Год + 1
		ИНАЧЕ ВТсГодом.Год
	КОНЕЦ КАК Период
ИЗ
	ВТсГодом КАК ВТсГодом,
	(ВЫБРАТЬ
		МЕСЯЦ(МАКСИМУМ(ВТсГодом.Месяц)) КАК ПоследнийМесяц
	ИЗ
		ВТсГодом КАК ВТсГодом) КАК ВЗМесяц

Напоминаю, Месяц – дата начала месяца. А вот ПоследнийМесяц – это номер месяца в году. И Период – это номер года, в котором заканчивается соответствующий период длиной в год.
Соответственно, делаю группировку по периоду:

 

 

Результат просто восхитительный:

 

 

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

 

 

Примечательно, что здесь все три диаграммы – на самом деле одно и то же. Они ведь принадлежат одному и тому же варианту отчета. А значит, все, что прописано в закладках под структурой, относится ко всем трем сразу.
Теперь остается лишь в процедуре ПриКомпоновкеРезультата() программно переставлять галочки в начале основных ветвей:

…
    НастройкиКомпоновки = КомпоновщикНастроек.ПолучитьНастройки();
    
    // Выбор ветви структуры отчета
    
    Если ГруппировкаДиаграмм = Перечисления.ГруппировкаДиаграмм.ГруппироватьПоГодам Тогда
    
        НастройкиКомпоновки.Структура[0].Использование = Ложь;
        НастройкиКомпоновки.Структура[1].Использование = Истина;
        НастройкиКомпоновки.Структура[2].Использование = Ложь;
    
    ИначеЕсли ГруппировкаДиаграмм = Перечисления.ГруппировкаДиаграмм.ГруппироватьПоПериодам Тогда
    
        НастройкиКомпоновки.Структура[0].Использование = Ложь;
        НастройкиКомпоновки.Структура[1].Использование = Ложь;
        НастройкиКомпоновки.Структура[2].Использование = Истина;
    
    Иначе
    
        НастройкиКомпоновки.Структура[0].Использование = Истина;
        НастройкиКомпоновки.Структура[1].Использование = Ложь;
        НастройкиКомпоновки.Структура[2].Использование = Ложь;
    
    КонецЕсли;
    
    МакетКомпоновки = КомпоновщикМакета.Выполнить(СхемаКомпоновкиДанных,
        НастройкиКомпоновки,ДанныеРасшифровки);
…

Вот и все. Комментарии приветствуются.

Специальные предложения

Оставьте свое сообщение

См. также

Как просто запомнить алгоритм программного вывода в СКД Промо

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

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

01.09.2017    58603    unichkin    19    

СКД: не очищается результат при формировании отчета

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

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

30.01.2023    362    user1728007    1    

Особенность задания периода в запросе в СКД

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

Не используйте предопределённые названия переменных НачалоПериода, КонецПериода в текстах запросов в СКД. Остальное можно не читать.

11.11.2022    1423    slicem    10    

Разрабатываем отчет на СКД, содержащий данные из расширения

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

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

17.10.2022    2331    al_zzz    4    

Хитрости СКД. Часть 4

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

Столкнулся с тем, что мне приходится писать гору отчетов. Во многих приходится использовать повторяющиеся приемы. Решил написать шпаргалку, которая, надеюсь пригодится не только мне. В этой статье: Работа с 2 схемами в одном отчете, когда данные одной схемы являются исходными для другой. Копирование пользовательских отборов из одной схемы в другую. Корректная модификация формы отчета БСП.

12.10.2022    4249    milkers    17    

В помощь начинающим 1С-программистам: СКД. Отчет с разбивкой по периодам (год, месяц) и детализацией по документам

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

В помощь начинающим программистам. Такой информативный отчет мы создадим с помощью Системы компоновки данных. Чтобы научиться создавать и более сложные отчеты, рекомендую к прочтению книгу Е.Ю. Хрусталевой "Разработка сложных отчетов в 1С: Предприятие. Система Компоновки Данных".

18.07.2022    3994    Pproksima    1    

СКД программно для обработки (не отчета) + программное восстановление значений полей из настроек для управляемых форм Промо

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

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

29.01.2014    99577    anig99    27    

Хитрости СКД. Часть 3

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

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

28.05.2022    5977    milkers    11    

КУ! или Нарезка графика продолжается

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

Продолжение публикации https://infostart.ru/public/1639182/. Как справиться с неудачным отображением концов графика. Проверено в версии 8.3.13.1644.

23.04.2022    662    AnatolPopov    0    

СКД. Вставка разрыва страницы Промо

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

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

29.10.2011    59451    stoptime    58    

Отладка СКД

СКД Система компоновки данных Система компоновки данных Бесплатно (free) Бесплатно (free)

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

08.02.2022    8810    ProgrammingStore    5    

Программная работа и компоненты СКД

СКД Система компоновки данных Система компоновки данных Бесплатно (free) Бесплатно (free)

На митапе «Практика применения СКД» выступил архитектор Digital Business Петр Базелюк. Он рассказал о том, как работать с СКД программно, и как, используя общедоступную библиотеку FoxyLink, создать свой процессор вывода результата СКД напрямую в формат JSON или в CSV.

04.02.2022    3995    pbazeliuk    4    

Реализация отборов на форме с помощью СКД

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

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

28.12.2021    10917    quazare    6    

Как указать время в периоде типового отчета (СтандартныйПериод, СКД) в системах класса WMS, MES, SCADA, АСУ ТП на 1С, построить отчет за период с временем?

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

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

13.12.2021    3406    SizovE    0    

Отбор/фильтр в отчетах/СКД/обработках 1C: БП, УТ, ERP, Кронос: WMS по файлу Excel, текстовому файлу или списку текстовых строк (номер документа, артикул, ИНН, QR-код, штрих-код, наименование)

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

Как построить отчет Анализ продаж или Остатки товаров с отбором/фильтром по списку кодов товаров/артикулов или ИНН покупателей из Эксель файла? Покажем, какой код нужно добавить в конфигурацию 1С (в том числе нетиповую), чтобы в любом отчете/отборе СКД/обработке можно было заполнять отбор по excel файлу, текстовому файлу или просто по списку строк - удобно и быстро.

23.11.2021    3663    SizovE    3    

Варианты применения СКД вне отчетов в отраслевых конфигурациях

СКД Система компоновки данных Система компоновки данных Бесплатно (free) Бесплатно (free)

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

18.11.2021    3397    drmaxart    0    

Кейсы решения задач на СКД

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

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

08.11.2021    5747    echo77    7    

Грабли на СКД

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

Наиболее частые проблемы, с которыми сталкиваются программисты 1С при разработке отчетов на СКД.

02.11.2021    11539    echo77    17    

Программное создание отчета на СКД с расшифровкой (обычные формы)

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

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

04.10.2021    2952    Neti    4    

Программное открытие отчета СКД с параметрами и отбором

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

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

07.08.2021    22702    Eugen-S    24    

Объект "Схема запроса" и расширения языка запросов СКД

СКД Платформа 1С v8.3 Платформа 1С v8.3 Запросы Запросы Россия Россия Бесплатно (free) Бесплатно (free)

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

18.07.2021    3222    mysm    14    

Изменение расшифровки макета СКД до компоновки

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

Это не про работу с данными расшифровки. Это про изменение расшифровок полей ДО того, как СКД выполнилась. Быстрый способ сделать нужные расшифровки.

12.07.2021    3834    Yashazz    7    

Чтоб в СКД по таблице значений был порядок!

СКД Система компоновки данных Система компоновки данных Бесплатно (free) Бесплатно (free)

Сортировка СКД и источник - таблица значений. Заметка.

28.06.2021    2498    Yashazz    0    

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

СКД Платформа 1С v8.3 Платформа 1С v8.3 Бесплатно (free) Бесплатно (free)

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

14.06.2021    5382    maraton1185    4    

Нестандартное использование СКД

СКД Система компоновки данных Система компоновки данных Бесплатно (free) Бесплатно (free)

Программист 1С в компании «БКС-технологии» Алексей Шиянов в ходе Infostart Meetup Novosibirsk продемонстрировал необычный способ использования СКД и сравнил результаты заполнения движений документа через СКД с классическим подходом к заполнению движений через запросы и циклы.

14.04.2021    5334    user1127305    12    

Эффективные приемы разработки

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

На Infostart Meetup Ekaterinburg.Online выступил Сергей Наумов – руководитель центра аналитики и консалтинга WiseAdvice. Сергей поделился с коллегами приемами разработки, которые помогут избежать потенциальных проблем при реализации сложных проектов.

07.04.2021    4886    SergeyN    13    

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

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

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

02.04.2021    2280    parshachello    2    

Полезные примеры СКД, ч.1

СКД Система компоновки данных Система компоновки данных Бесплатно (free) Бесплатно (free)

Подборка видео по решению различных задач в отчетах на СКД.

30.03.2021    21417    Neti    21    

Перенос/копирование и установка отбора/фильтра/периода при интерактивном переключении или смене варианта отчета/СКД в БСП 3.1 (1C ERP, УТ, БП, ...)

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

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

18.01.2021    3246    SizovE    4    

Пользовательское поле СКД одной процедурой

СКД Платформа 1С v8.3 Платформа 1С v8.3 Бесплатно (free) Бесплатно (free)

Быстрое создание пользовательского поля "выражение" одной процедурой

05.08.2020    3011    Yashazz    0    

Роль "Остатки" поля набора данных СКД в отчете и в расшифровке

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

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

24.05.2020    11839    kasper076    18    

Макет оформления в отчете с несколькими СКД

СКД Система компоновки данных Система компоновки данных Россия Россия Бесплатно (free) Бесплатно (free)

Как заставить работать макет оформления в отчёте с несколькими СКД.

14.05.2020    6514    vendim    4    

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

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

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

29.04.2020    18346    ixijixi    48    

Ограничения полей, или как обмануть СКД?

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

Каждое из ограничений полей можно обойти. Рассмотрим варианты обхода и способы обезопасить свой отчет.

15.04.2020    25923    SeiOkami    43    

Работа с запросами в 1С СКД. Отладка СКД

СКД Запросы Запросы Система компоновки данных Система компоновки данных Россия Россия Бесплатно (free) Бесплатно (free)

В предыдущем разделе мы изучали с вами особенности работы с запросами в СКД. Для изучения (отладки) работы различных схем компоновки данных я использовал консоль компоновки данных.

15.04.2020    6767    ProgrammingStore    3