CALCULATE
platí pro:Počítaný sloupecPočítaná tabulkamíravizuální
Vyhodnotí výraz v upraveném kontextu filtru.
Poznámka
K dispozici je také funkce CALCULATETABLE. Provádí přesně stejné funkce, s výjimkou toho, že upravuje kontext filtru použitý u výrazu, který vrací objekt tabulky.
Syntax
CALCULATE(<expression>[, <filter1> [, <filter2> [, …]]])
Parametry
Semestr | Definice |
---|---|
expression |
Výraz, který se má vyhodnotit. |
filter1, filter2,… |
(Volitelné) Logické výrazy nebo výrazy tabulky, které definují filtry nebo modifikační funkce filtru. |
Výraz použitý jako první parametr je v podstatě stejný jako míra.
Filtry můžou být:
- Logické výrazy filtru
- Výrazy filtru tabulky
- Funkce úprav filtru
Pokud existuje více filtrů, lze je vyhodnotit pomocí logickéhooperátoru
Logické výrazy filtru
Logický filtr výrazů je výraz, který se vyhodnotí jako TRUE
nebo FALSE
. Existuje několik pravidel, která musí dodržovat:
- Mohou odkazovat na sloupce z jedné tabulky.
- Nemůžou odkazovat na míry.
- Nemůžou použít vnořenou funkci CALCULATE.
Od verze Power BI Desktopu ze září 2021 platí také toto:
- Nemůžou používat funkce, které prohledávají nebo vracejí tabulku, pokud nejsou předány jako argumenty agregačním funkcím.
-
mohou obsahovat agregační funkci, která vrací skalární hodnotu. Například
Total sales on the last selected date = CALCULATE ( SUM ( Sales[Sales Amount] ), 'Sales'[OrderDateKey] = MAX ( 'Sales'[OrderDateKey] ) )
Výraz filtru tabulky
Filtr výrazů tabulky použije objekt tabulky jako filtr. Může se jednat o odkaz na tabulku modelu, ale s větší pravděpodobností se jedná o funkci, která vrací objekt tabulky. Pomocí funkce FILTER můžete použít komplexní podmínky filtru, včetně těch, které nelze definovat pomocí logického výrazu filtru.
Modifikační funkce filtru
Modifikační funkce filtru umožňují provádět více než pouhé přidávání filtrů. Poskytují vám další ovládací prvek při úpravě kontextu filtru.
Funkce | Účel |
---|---|
REMOVEFILTERS | Odeberte všechny filtry nebo filtry z jednoho nebo více sloupců tabulky nebo ze všech sloupců jedné tabulky. |
ALL 1, ALLEXCEPT, ALLNOBLANKROW | Odeberte filtry z jednoho nebo více sloupců nebo ze všech sloupců jedné tabulky. |
KEEPFILTERS | Přidejte filtr bez odebrání existujících filtrů ve stejných sloupcích. |
USERELATIONSHIP | Zapojte neaktivní relaci mezi souvisejícími sloupci, v takovém případě se aktivní relace automaticky stane neaktivní. |
CROSSFILTER | Změňte směr filtru (z obou na jeden nebo z jednoho na oba) nebo zakažte relaci. |
1 Funkce ALL a její varianty se chovají jako modifikátory filtru i jako funkce, které vracejí objekty tabulky. Pokud nástroj podporuje funkci REMOVEFILTERS, je lepší ji použít k odebrání filtrů.
Návratová hodnota
Hodnota, která je výsledkem výrazu.
Poznámky
Pokud jsou k dispozici výrazy filtru, funkce CALCULATE upraví kontext filtru tak, aby vyhodnotil výraz. Pro každý výraz filtru existují dva možné standardní výsledky, pokud není výraz filtru zabalený do funkce KEEPFILTERS:
- Pokud sloupce (nebo tabulky) nejsou v kontextu filtru, přidají se do kontextu filtru nové filtry, aby se výraz vyhodnotil.
- Pokud už jsou sloupce (nebo tabulky) v kontextu filtru, stávající filtry se přepíšou novými filtry, aby se vyhodnotil výraz CALCULATE.
Funkce CALCULATE použitá bez filtrů dosáhne konkrétního požadavku. Přemísní kontext řádku na kontext filtru. Vyžaduje se, když je potřeba vyhodnotit výraz (ne míru modelu), který shrnuje data modelu v kontextu řádku. K tomuto scénáři může dojít ve vzorci počítaného sloupce nebo při vyhodnocení výrazu ve funkci iterátoru. Všimněte si, že při použití míry modelu v kontextu řádku je přechod kontextu automatický.
Tato funkce není podporována pro použití v režimu DirectQuery při použití v počítaných sloupcích nebo pravidlech zabezpečení na úrovni řádků (RLS).
Příklady
Následující definice míry tabulky Sales vytvoří výsledek výnosů, ale pouze pro produkty, které mají modrou barvu.
Příklady v tomto článku můžete použít s ukázkovým modelem Adventure Works DW 2020 Power BI Desktopu. Pokud chcete model získat, podívejte se na DAX ukázkový model.
Blue Revenue =
CALCULATE(
SUM(Sales[Sales Amount]),
'Product'[Color] = "Blue"
)
Kategorie | Sales Amount | Modré výnosy |
---|---|---|
Příslušenství | 1 272 057,89 Kč | 165 406,62 Kč |
Kola | 94 620 526,21 Kč | 8 374 313,88 Kč |
Oděv | 2 117 613,45 Kč | 259 488,37 Kč |
Součásti | 11 799 076,66 Kč | 803 642,10 Kč |
celkem | 109 809 274,20 | 9 602 850,97 USD |
Funkce CALCULATE vyhodnotí součet tabulky SalesSales Amount (Částka prodeje) sloupec v upraveném kontextu filtru. Do tabulky Product table Color se přidá nový filtr nebo filtr přepíše libovolný filtr, který už je u sloupce použitý.
Následující definice míry Sales tabulky vytvoří poměr prodeje oproti prodeji pro všechny prodejní kanály.
Kanál | Sales Amount | Revenue % Total Channel |
---|---|---|
Internet | 29 358 677,22 Kč | 26,74% |
Distributor | 80 450 596,98 Kč | 73,26% |
celkem | 109 809 274,20 | 100.00% |
Revenue % Total Channel =
DIVIDE(
SUM(Sales[Sales Amount]),
CALCULATE(
SUM(Sales[Sales Amount]),
REMOVEFILTERS('Sales Order'[Channel])
)
)
Funkce DIVIDE vydělí výraz, který sečte tabulky SalesSales Amount column value (v kontextu filtru) stejným výrazem v upraveném kontextu filtru. Je to CALCULATE funkce, která upravuje kontext filtru pomocí funkce REMOVEFILTERS, což je modifikátor filtru. Odebere filtry ze sloupce Sales Order table Channel.
Následující Customer table calculated column definition klasifikuje zákazníky do třídy věrnosti. Jedná se o velmi jednoduchý scénář: Když jsou výnosy vytvořené zákazníkem nižší než 2500 USD, jsou klasifikovány jako Nízké; jinak jsou high.
Customer Segment =
IF(
CALCULATE(SUM(Sales[Sales Amount]), ALLEXCEPT(Customer, Customer[CustomerKey])) < 2500,
"Low",
"High"
)
V tomto příkladu se kontext řádku převede na kontext filtru. Označuje se jako kontextový přechod. Funkce