BEREGNE
Gælder for: Beregning af målingsvisualisering for beregnet kolonne i beregnet tabel
Evaluerer et udtryk i en ændret filterkontekst.
Bemærk
Der er også funktionen CALCULATETABLE . Den udfører præcis den samme funktionalitet, bortset fra at den ændrer den filterkontekst , der anvendes på et udtryk, der returnerer et tabelobjekt.
Syntaks
CALCULATE(<expression>[, <filter1> [, <filter2> [, …]]])
Parametre
Begreb | Definition |
---|---|
udtryk | Det udtryk, der skal evalueres. |
filter1, filter2,... | (Valgfrit) Booleske udtryk eller tabeludtryk, der definerer filtre eller filterændringsfunktioner. |
Det udtryk, der bruges som den første parameter, er stort set det samme som en måling.
Filtre kan være:
- Booleske filterudtryk
- Tabelfilterudtryk
- Filterændringsfunktioner
Når der er flere filtre, kan de evalueres ved hjælp af den logiske OPERATOR AND (&&), hvilket betyder, at alle betingelser skal være TRUE eller af den logiske OPERATOR OR (||), hvilket betyder, at begge betingelser kan være sande.
Booleske filterudtryk
Et boolesk udtryksfilter er et udtryk, der evalueres til TRUE eller FALSE. Der er flere regler, som de skal overholde:
- De kan referere til kolonner fra en enkelt tabel.
- De kan ikke referere til målinger.
- De kan ikke bruge en indlejret CALCULATE-funktion.
Fra og med udgivelsen af Power BI Desktop fra september 2021 gælder følgende også:
- De kan ikke bruge funktioner, der scanner eller returnerer en tabel, medmindre de overføres som argumenter til sammenlægningsfunktioner.
- De kan indeholde en sammenlægningsfunktion, der returnerer en skalarværdi. F.eks.
Total sales on the last selected date = CALCULATE ( SUM ( Sales[Sales Amount] ), 'Sales'[OrderDateKey] = MAX ( 'Sales'[OrderDateKey] ) )
Tabelfilterudtryk
Et tabeludtryksfilter anvender et tabelobjekt som filter. Det kan være en reference til en modeltabel, men mere sandsynligt er det en funktion, der returnerer et tabelobjekt. Du kan bruge funktionen FILTER til at anvende komplekse filterbetingelser, herunder dem, der ikke kan defineres af et boolesk filterudtryk.
Funktioner til filterændring
Filterændringsfunktioner gør det muligt at gøre mere end blot at tilføje filtre. De giver dig yderligere kontrol, når du ændrer filterkontekst.
Funktion | Formål |
---|---|
REMOVEFILTERS | Fjern alle filtre eller filtre fra en eller flere kolonner i en tabel eller fra alle kolonner i en enkelt tabel. |
ALLE 1, ALLEXCEPT, ALLNOBLANKROW | Fjern filtre fra en eller flere kolonner eller fra alle kolonner i en enkelt tabel. |
KEEPFILTERS | Tilføj filter uden at fjerne eksisterende filtre på de samme kolonner. |
USERELATIONSHIP | Aktivér en inaktiv relation mellem relaterede kolonner, hvorefter den aktive relation automatisk bliver inaktiv. |
CROSSFILTER | Rediger filterretningen (fra begge til enkelt eller fra enkelt til begge), eller deaktiver en relation. |
1 Funktionen ALL og dens varianter fungerer både som filtermodifikatorer og som funktioner, der returnerer tabelobjekter. Hvis funktionen REMOVEFILTERS understøttes af dit værktøj, er det bedre at bruge den til at fjerne filtre.
Returværdi
Den værdi, der er resultatet af udtrykket.
Bemærkninger
Når der angives filterudtryk, ændrer funktionen CALCULATE filterkonteksten for at evaluere udtrykket. For hvert filterudtryk er der to mulige standardresultater, når filterudtrykket ikke er ombrudt i funktionen KEEPFILTERS:
- Hvis kolonnerne (eller tabellerne) ikke er i filterkonteksten, føjes der nye filtre til filterkonteksten for at evaluere udtrykket.
- Hvis kolonnerne (eller tabellerne) allerede er i filterkonteksten, overskrives de eksisterende filtre af de nye filtre for at evaluere udtrykket CALCULATE.
Funktionen CALCULATE, der bruges uden filtre , opfylder et bestemt krav. Den skifter rækkekontekst til filterkontekst. Det er påkrævet, når et udtryk (ikke en modelmåling), der opsummerer modeldata, skal evalueres i rækkekontekst. Dette scenarie kan forekomme i en formel for en beregnet kolonne, eller når et udtryk i en iteratorfunktion evalueres. Bemærk, at når en modelmåling bruges i rækkekontekst, sker kontekstovergangen automatisk.
Denne funktion understøttes ikke til brug i DirectQuery-tilstand, når den bruges i beregnede kolonner eller RLS-regler (row-level security).
Eksempler
Følgende målingsdefinition for tabellen Sales giver et indtægtsresultat, men kun for produkter, der har farven blå.
Eksempler i denne artikel kan bruges sammen med eksempelmodellen Adventure Works DW 2020 Power BI Desktop. Hvis du vil hente modellen, skal du se DAX-eksempelmodel.
Blue Revenue =
CALCULATE(
SUM(Sales[Sales Amount]),
'Product'[Color] = "Blue"
)
Kategori | Salgsbeløb | Blå indtægt |
---|---|---|
Accessories | 1.272.057,89 USD | 165.406,62 USD |
Cykler | 94.620.526,21 USD | 8.374.313,88 USD |
Tøj | 2.117.613,45 USD | 259.488,37 USD |
Komponenter | 11.799.076,66 USD | 803.642,10 USD |
Total | 109.809.274,20 USD | 9.602.850,97 USD |
Funktionen CALCULATE evaluerer summen af tabellen Sales Amount i en ændret filterkontekst. Der føjes et nyt filter til kolonnen Color i tabellen Product – eller filteret overskriver et filter, der allerede er anvendt på kolonnen.
Følgende målingsdefinition for tabellen Sales giver et forhold mellem salg og salg for alle salgskanaler.
Kanal | Salgsbeløb | Indtægt i % kanal i alt |
---|---|---|
Internet | 29.358.677,22 USD | 26.74% |
Reseller | 80.450.596,98 USD | 73.26% |
Total | 109.809.274,20 USD | 100.00% |
Revenue % Total Channel =
DIVIDE(
SUM(Sales[Sales Amount]),
CALCULATE(
SUM(Sales[Sales Amount]),
REMOVEFILTERS('Sales Order'[Channel])
)
)
Funktionen DIVIDE dividerer et udtryk, der opsummerer kolonneværdien Sales Amount (i filterkonteksten) med det samme udtryk i en ændret filterkontekst. Det er funktionen CALCULATE, der ændrer filterkonteksten ved hjælp af funktionen REMOVEFILTERS, som er en filterændringsfunktion. Den fjerner filtre fra kolonnen Channel i tabellen Sales Order.
Følgende definition af en beregnet kolonne i tabellen Customer klassificerer kunder i en loyalitetsklasse. Det er et meget simpelt scenarie: Når den indtægt, der produceres af kunden, er mindre end $2.500, klassificeres de som Low, ellers er de Høje.
Customer Segment =
IF(
CALCULATE(SUM(Sales[Sales Amount]), ALLEXCEPT(Customer, Customer[CustomerKey])) < 2500,
"Low",
"High"
)
I dette eksempel konverteres rækkekontekst til filterkonteksten. Det kaldes kontekstovergang. Funktionen ALLEXCEPT fjerner filtre fra alle kolonner i tabellen Customer undtagen kolonnen CustomerKey .
Relateret indhold
Filterkontekst
Rækkekontekst
Funktionen CALCULATETABLE
Filterfunktioner