Dax Pro Solutions – Telegram
Dax Pro Solutions
2.46K subscribers
36 photos
3 videos
22 links
Dax, Power BI, Data Modelling and Architecture
Download Telegram
🌠 Сравнение двух рандомных месяцев с динамическим заголовком.

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

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

В PBIX файле я постарался максимально подробно и пошагово описать процесс разработки. Также, показал как работать с FP нестандартным способом - попробуйте развить это направление =)

👉🏻PBIX во вложении👈🏻

(Только для облачной версии! Для RS похожее решение тут: https://news.1rj.ru/str/dax_pro/20)
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥52👍162🤓2
This media is not supported in your browser
VIEW IN TELEGRAM
📈 Как из RS или PBI Desktop отправить графики в Power Point без потери качества.

Все просто:
1️⃣ Файл - экспорт - PDF ( или просто Ctrl + P )
2️⃣ Открываем PDF в Wondershare PDFelement или аналогичной программе, которая может работать с Power Point
3️⃣ Экспортируем в Power Point

// да, не интерактивные графики, как в облачной версии. Но без потери качества.
Также, эта программа может из папки с PDF собрать все сразу в один ppt
Please open Telegram to view this post
VIEW IN TELEGRAM
👍25
📈 Управляемые столбцы на RS

Если хочется функционала Fields Parameters или группировать измерения без написания больших SWITCH () функций, то вы можете воспользоваться Calculation Groups механизмом.

‼️ Наиболее важные ограничения и предостережения:

🔴 это Группы расчета (Calculation Groups или CG) и создание/включения их в модели автоматически отключит встроенные механизмы агрегирования по столбцам таблиц (т.е. все меры нужно будет в дальнейшем писать руками);

🔴 CG влияют на вычисления в отчетах или замещают их, если их применять/использовать в модели неверно;

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

🔴 Сворачивание иерархии до верхнего уровня в матрицах и визуалах с механизмом Drill-Down в полях с Calculation Groups также не будет отрабатывать.


👉🏻PBIX для разбора внутри👈🏻

Замена FP на RS may 22 +
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥294
📈 Имитация Field Parameters на PBI Report Server с неравными периодами.

Ограничения:
1. Если в таблицах источников осей есть пустые строки, при создании справочника для осей методом Unpivot в PQ они будут удалены. Требуется перезаполнять пустоту на любое текстовое значение.
2. Такой подход "раздувает" модель и не рекомендуется в проектах с большим количеством уникальных в справочниках.

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

год – показывать все доступные годы;
квартал – только кварталы 2х последних лет от текущей (сегодня) даты;
месяц – последние 12 месяцев от текущей даты.
=============================

🔧 Порядок решения:
1. Создание вычисляемой таблицы с разной гранулярностью год-квартал-месяц в одном столбце.
2. Сортировка поля выбора гранулярности периодов по дополнительному целочисленному столбцу.
3. Создание связи 'Calendar' [Date] 1 <> * 'Periods For Select' [Date].
'Calendar' на стороне 1, наша 'Periods For Select' на стороне многие, но связь двунаправленная и неактивная (чтобы избежать массы проблем с другими расчетами сдвигов во времени по основному календарю).
В облачной версии можно было бы просто сделать связь многие ко многим и направление фильтра от 'Periods For Select' к 'Calendar', но версии RS не поддерживают такой тип связей в стандартной версии.

4. Написание меры для визуализаций с переключаемой осью, чтобы активировать связь:
Calculate (
....,
Userelationship(
'Calendar' [Date],
'Periods For Select' [Date]
)
)
👉🏻PBIX во вложении👈🏻

RS May 2022+
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
👍16🔥72
This media is not supported in your browser
VIEW IN TELEGRAM
📈 Переключение неравных периодов
с помощью Field Parameters.

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

ЗАДАЧА
Автоматическое изменение гранулярности оси по условиям:

🔶 если выбран 1 месяц, то выводить ось по датам;
🔶 если выбрано несколько месяцев, изменить грануляцию оси на месяцы;
🔶 если выбрано несколько лет, изменить грануляцию оси на года.

======================================
Последовательность решения:
1. Формируем необходимую таблицу параметров через Новый параметр и выбираем поля из Календаря (Год-Месяц-Дата)

2. Помещаем поле [Month_Date_Axys] в ось нашего графика, а в Slicer поместим год и месяц из таблицы Calendar.

3. Пишем меру, которая будет проверять какой период выбран:
Filter = 
VAR _countmonths = CALCULATE(COUNTROWS(VALUES('Calendar'[Month])),ALLSELECTED('Calendar'))
VAR _filter =
SWITCH(
TRUE(),
_countmonths=1,0,
_countmonths<13,1,
2
)
RETURN
COUNTROWS(
FILTER(
VALUES('Month_Date_Axys'[Month_Date Order]),
'Month_Date_Axys'[Month_Date Order]=_filter
)
)

4. Помещаем меру в панель фильтров на уровень визуального элемента и применяем TOPN =1 фильтрацию.

👉🏻PBIX с подробным описанием внутри👈🏻
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥28👍91
📈 Переключение неравных периодов с помощью Field Parameters V2

Основная задача:

При выборе месяца в слайсере, показать в матрице:
· факт за весь прошлый год,
· план на весь текущий год,
· поквартально факт текущего года, но со сдвигом в -1 квартал от текущего выбранного и обнулением в новом году (поступление данных с запозданием в квартал).

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


Порядок решения:

1. Пишем основные меры, которые будут участвовать в расчетах Field Parameters;
2. Формируем несколько таблиц FP, так как они будут выступать в роли столбцов в матрице.
Для Sales PY меняем имя параметра следующей конструкцией:
Sales PY = 
GENERATE(
ALLNOBLANKROW('Calendar'[Year]),
{
(FORMAT([Year]-1,"yyyy"), NAMEOF('_Measures'[Amount PY]), 0)
}
)

3. Plan CY. Принцип такой же как был описан ранее;
4. Создаём последний параметр, который будет служить для расчета показателей поквартально. Для этого помещаем в FP сразу три меры : [Amount Q1], [Amount Q2], [Amount Q3].
5. Меняем DAX последнего параметра:
FC = 
FILTER(
GENERATE(
FILTER(
CROSSJOIN(
SELECTCOLUMNS(ALLNOBLANKROW('Calendar'[Quarter]),"CurentQuarter",[Quarter]),
ALLNOBLANKROW('Calendar'[Quarter])
),
DAY([CurentQuarter])>DAY([Quarter])
&&YEAR([CurentQuarter])=YEAR([Quarter])
),
{
("FC1 "&YEAR([Quarter]), NAMEOF('_Measures'[Amount Q1]), 0),
("FC2 "&YEAR([Quarter]), NAMEOF('_Measures'[Amount Q2]), 1),
("FC3 "&YEAR([Quarter]), NAMEOF('_Measures'[Amount Q3]), 2)
}
),
[Value3]=INT(DAY([Quarter]))-1
)


👉🏻Скачать PBIX👈🏻

Только для облака
Please open Telegram to view this post
VIEW IN TELEGRAM
👍26🔥21
Media is too big
VIEW IN TELEGRAM
🌟 Настройка вывода недель по параметрам. Какие решения существуют?

Основная задача:

При выборе недели в срезе, показать в матрице:
· переключаемое значение за выбранную неделю,
· переключаемое значение за Х недель вперед,
· дать возможность выбрать значение ячеек матрицы.


Я подготовил для вас 4 способа решения этой задачи при помощи:
+ Field Parameters ( 2 варианта )
+ Calculation Groups
+ Field Parameters + Calculation Groups

👉🏻PBIX во вложении👈🏻

// Буду рад вашим комментариям. Кто хочет, может предложить еще способы реализации и мы оценим их оптимальность и быстродействие.
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥32👍15