Vytvoření tabulky data v LuckyTemplates
Zjistěte, proč je důležité mít vyhrazenou tabulku s daty v LuckyTemplates, a naučte se nejrychlejší a nejefektivnější způsob, jak toho dosáhnout.
V tomto blogovém příspěvku se budeme zabývat některými problematickými problémy v časové inteligenci, zejména těmi, které jsou způsobeny týdenní granularitou a problémy, které mohou být způsobeny nepravidelným počtem týdnů v roce. K získání přesné časové inteligence v jazyce DAX použijeme offsety.
Dnes pro vás máme zajímavý scénář. Nedávno se to několikrát objevilo na fóru LuckyTemplates. Lidé chtěli udělat vizuál (což by mohl být spojnicový graf nebo sloupcový graf) a dynamicky jej měnit k datu zahájení. Celé video tohoto tutoriálu si můžete prohlédnout ve spodní části tohoto blogu.
V tomto případě jsme použili stejný soubor dat, který jsme zpracovali pro průměrnou spotovou cenu za barel ropy . Namísto toho, abychom vždy začínali na začátku v lednu, jsme chtěli mít možnost kliknout na vizuál, změnit jej na jiné datum zahájení, ale vždy zobrazit data za jeden rok.
Obsah
Ukázkové scénáře časové inteligence v DAX
Existuje několik důvodů, proč byste mohli chtít tuto techniku provést. Můžete to použít, pokud máte metriku, která se neustále upravuje, pokud jde o způsob jejího výpočtu. Možná budete chtít zobrazit pouze data z období přenastavení dopředu.
Dalším důvodem, proč to použít, je, pokud to chcete vizualizovat animovaným způsobem. To v podstatě vezme vaše data a zobrazí je dynamicky, jakmile kliknete na přístup ke hře.
V tomto vizuálu můžeme změnit počáteční datum měsíc po měsíci, abychom ukázali, jak se mění v průběhu 12 měsíců v průběhu času. Toto je zajímavý a užitečný vizuál pro různé obchodní případy, ale teoreticky představuje také řadu klíčových problémů souvisejících s DAX a datovým modelováním.
Pojďme do LuckyTemplates a podívejme se nejprve na náš datový model. Jedná se o opravdu jednoduchý datový model s rozšířenou tabulkou dat a tabulkou spotových cen propojenou s daty.
Použití offsetů pro časovou inteligenci v DAX
Jedna z věcí, na kterých budeme pracovat, jsou offsety . Posuny v tabulce rozšířených dat se počítají dynamicky. Pokaždé, když je sestava aktualizována nebo otevřena, prochází kódem M. Například v měsíčním offsetu přiřadí aktuální měsíc 0, předchozí měsíc -1 a dva měsíce zpět -2. Při pohledu do budoucna přiděluje dalšímu měsíci +1 a na dva měsíce v budoucnu +2.
Jedná se o jednoduchý koncept, ale neuvěřitelně výkonný, když pracujete s časovou inteligencí v jazyce DAX a pracujete s měsíci , čtvrtletími a týdny . Pokud nepoužíváte offset, někdy to ve vašich výpočtech vytváří značné množství složitosti.
Použití offsetů znamená použití souvislé řady čísel, kde návrat za měsíc je vždy -1 a postupný měsíc dopředu je vždy +1 bez ohledu na to, kde v roce se nacházíte.
Implementace strategie Rubber Duck pro časovou inteligenci v DAX
V minulosti jsem mluvil o gumovém duckingu , což je verbalizace vaší strategie nahlas, než začnete psát svůj DAX.
Přemýšlím nahlas, jak to zvládnu z měsíčního kontextu pomocí časové inteligence v DAX. Začal bych něco na základě vybraného roku a měsíce a vybral bych ty pomocí odpojené tabulky, protože když se nad tím zamyslíte, každý další výběr bude zahrnovat křížení let (s výjimkou ledna).
Řekněme, že chceme 12 měsíců počínaje březnem, skončíme s alespoň dvěma měsíci v následujícím roce. Pokud použijeme připojený slicer, můžeme filtrovat pouze pro daný rok a nebudeme moci filtrovat do dalšího roku.
Sklizeň offsetů od data zahájení
Udělejme to s připojenou tabulkou pro měsíc i rok. Nejprve musíme sklidit první offset, který se týká počátečního data.
A pak chceme posunout tento offset dopředu o 12 měsíců a pak se podívat pouze na data, která jsou v rámci tohoto souboru offsetů. Dovolte mi, abych vám ukázal, jak to vypadá v jazyce DAX.
Výpočet měsíčního rozsahu
Toto je naše míra pro měsíčník v rámci rozsahu , kde vybíráme náš rok (který jsme sklidili z tabulky odpojených roků) a náš měsíc (který jsme sklidili z tabulky odpojených měsíců).
Máme také tento další parametr, kde pokud není proveden žádný výběr, bude výchozí leden. Tento parametr je primárně určen pouze pro účely ladění.
Výpočet Počátečního a Koncového měsíce offsetů
Podívejme se na offset počátečního měsíce pomocí výpočtu MAX offsetu. Odebereme všechny filtry v tabulce dat a filtrujeme až na vybraný měsíc a vybraný rok. Pro každý měsíc by měl existovat pouze jeden posun, který odpovídá danému měsíci a roku.
Od tohoto okamžiku můžeme vzít kompenzaci na konci měsíce , což je pouze kompenzace počátečního měsíce + 11 měsíců.
A pak se podíváme na každé vybrané datum a určíme, zda spadá do offsetu počátečního měsíce a offsetu na konci měsíce. pokud spadá do tohoto období, dáme mu 1 a pokud ne, dáme mu 0.
Pokud se v našem vizuálu vrátíme k měsíčnímu zobrazení, můžeme vidět vizuál V rámci rozsahu , který jsme nastavili jako rovný jedné. Zobrazuje tedy pouze měsíce od začátku do konce. Pokud například klikneme na únor, uvidíme únor až leden.
Výpočet týdenního rozsahu
Pojďme se podívat, jak to vypadá z týdenního hlediska. Vizuál zpočátku začíná v pořádku a trvá od týdne 1 do týdne 52. Zatím je to dobré.
Ale když klikneme na ostatní roky v kráječi roku, uvidíme 52. týden, zatímco někteří mají 53. týden, což představuje spoustu problémů. Na tomto příkladu vidíte, že se problém začíná projevovat.
Máme počáteční období rok 2020 a týden 15 , ale období ukončení je rok 2021 a týden 13 místo roku 2021 a týden 14 .
Pokud se vrátíme do týdne 1, můžeme vidět, že to začíná v pořádku, ale končí v týdnu 52. Pokud se podíváme na výpočet týdne 53 zde, maximální počet týdnů pro roky 2020 a 2021 je 53 týdnů. Toto nebude fungovat pro týdenní podrobnosti.
Pojďme se podívat, co můžeme udělat, aby to fungovalo. Potřebujeme opravit výpočet DAX přímo zde v této části:
Je to proto, že v některých případech je 51 správných, když rok má pouze 52 týdnů, ale pro rok, kde je 53 týdnů, toto poslední období vynechá. To je přesně to, co jsme viděli v dynamickém vizuálu několik týdnů, kde výpočet odstranil poslední období v letech 2020 a 2021.
Abychom to napravili, přejdeme k měření V rámci rozsahu Weekly Wrong , které ve skutečnosti vypadá jednodušeji než dřívější měření. Měli jsme počáteční měření offsetu a vypočítali jsme maximální offset. Poté jsme filtr zbavili dat a poté jsme filtr nasadili na vybraný týden a vybraný rok s předpokladem, že to povede ke správnému offsetu.
Ale to nefunguje, protože by nezáleželo na tom, jestli používáte maximální nebo minimální posun. Vše, co děláme, je obalování agregátorem, takže do příkazu CALCULATE nevkládáme holý sloupec.
Ale pokud se vrátíme zpět k ISO WeekNumber , můžeme vidět, že rok a číslo týdne jednoznačně neurčují týdenní posun v tomto prvním období.
Přišel jsem na neprůstřelný způsob, jak to udělat. Můžete použít MIN, ale dává větší smysl vytvořit toto měření Offsetu 1. týdne . Abychom dosáhli offsetu týdne 1, zabýváme se týdnem 2, protože se nikdy nerozdělí. Bez ohledu na to, zda je v roce 52 nebo 53 týdnů, týden 2 zůstává nedotčen.
V tomto výpočtu filtrujeme až na týden 2, abychom získali offset. A pak jakmile dostaneme offset za týden 2, odečteme od něj jen jeden. To nám jednoznačně poskytne offset 1. týdne. Tím se náš problém vyřeší.
Výpočet týdenního intervalu
A pak se vrátíme k našemu týdennímu měření v rámci rozsahu a napíšeme příkaz IF, kde je-li číslo sklizně za týden 1, vypočítáme posun prvního týdne. Pokud to není týden 1, vypočítáme pouze posun počátečního týdne jako v předchozím měsíčním výpočtu.
A pak offset na konci týdne bude offset na začátku týdne + maximální číslo týdne, které může být buď 52 nebo 53. Pak prostě odečteme 1, aby se počáteční offset nezapočítával dvakrát.
Můžeme udělat stejnou konstrukci, kterou jsme použili pro měsíční rozsah k filtrování týdnů, kde vše, co spadá mezi počáteční a koncový posun, dostane 1 a vše, co nedostane 0.
Potom do podokna filtru umístíme týdenní měření v rámci rozsahu. Všechno se kontroluje a vypadá přesně.
Můžeme kliknout na osu přehrávání a spustit týdenní granularitu. Vidíme, že funguje správně stejně jako v kontextu měsíce.
Závěr
Toto je docela hluboký ponor do časové inteligence v DAX, kde jsme diskutovali o tom, jak můžeme vyřešit některé problémy týkající se čísel týdnů. Doufám, že vám tento návod pomohl a poskytl vám některé další nástroje ve vaší sadě nástrojů, když se potýkáte s problematickou týdenní situací.
Pokud se vám obsah obsažený v tomto konkrétním tutoriálu líbil, nezapomeňte se přihlásit k odběru televizního kanálu LuckyTemplates. Neustále vychází obrovské množství obsahu ode mne a řady tvůrců obsahu, všichni se věnují zlepšování způsobu, jakým používáte LuckyTemplates a Power Platform.
Zjistěte, proč je důležité mít vyhrazenou tabulku s daty v LuckyTemplates, a naučte se nejrychlejší a nejefektivnější způsob, jak toho dosáhnout.
Tento stručný návod zdůrazňuje funkci mobilního hlášení LuckyTemplates. Ukážu vám, jak můžete efektivně vytvářet přehledy pro mobily.
V této ukázce LuckyTemplates si projdeme sestavy ukazující profesionální analýzy služeb od firmy, která má více smluv a zákaznických vztahů.
Pozrite si kľúčové aktualizácie pre Power Apps a Power Automate a ich výhody a dôsledky pre platformu Microsoft Power Platform.
Objavte niektoré bežné funkcie SQL, ktoré môžeme použiť, ako napríklad reťazec, dátum a niektoré pokročilé funkcie na spracovanie alebo manipuláciu s údajmi.
V tomto tutoriálu se naučíte, jak vytvořit dokonalou šablonu LuckyTemplates, která je nakonfigurována podle vašich potřeb a preferencí.
V tomto blogu si ukážeme, jak vrstvit parametry pole s malými násobky, abychom vytvořili neuvěřitelně užitečné přehledy a vizuály.
V tomto blogu se dozvíte, jak používat funkce hodnocení LuckyTemplates a vlastní seskupování k segmentaci ukázkových dat a jejich seřazení podle kritérií.
V tomto tutoriálu se budu zabývat konkrétní technikou, jak zobrazit kumulativní součet pouze do určitého data ve vašich vizuálech v LuckyTemplates.
Naučte se vytvářet a přizpůsobovat Bullet grafy v LuckyTemplates, které se používají hlavně pro měření výkonu oproti cílovým nebo předchozím rokům.