Del via


CALCULATE

gælder for:beregnet kolonneberegnet tabelberegning af målingvisualisering

Evaluerer et udtryk i en ændret filterkontekst.

Seddel

Der er også funktionen CALCULATETABLE. Den udfører præcis den samme funktionalitet, bortset fra at den ændrer den filterkontekst, anvendt på et udtryk, der returnerer et tabelobjekt.

Syntaks

CALCULATE(<expression>[, <filter1> [, <filter2> [, …]]])

Parametre

Udtryk Definition
expression 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 AND (&&) logiske operator, hvilket betyder, at alle betingelser skal være TRUEeller 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. For eksempel
    Total sales on the last selected date =
    CALCULATE (
        SUM ( Sales[Sales Amount] ),
        'Sales'[OrderDateKey] = MAX ( 'Sales'[OrderDateKey] )
    )
    

Tabelfilterudtryk

Et tabeludtryksfilter anvender et tabelobjekt som et 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.
ALL 1, ALLEXCEPTALLNOBLANKROW 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 ske 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ålingsdefinitionen Sales tabel 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
Tilbehør 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
i alt 109.809.274,20 USD 9.602.850,97 USD

Funktionen CALCULATE evaluerer summen af tabellen Saleskolonnen Sales Amount i en ændret filterkontekst. Der føjes et nyt filter til tabellen ProductKolonnen Color – eller filteret overskriver alle filtre, der allerede er anvendt på kolonnen.

Følgende målingsdefinitionen sales tabel giver et forhold mellem salg og salg for alle salgskanaler.

Kanal Salgsbeløb Indtægt % kanal i alt
Internet 29.358.677,22 USD 26.74%
Forhandler 80.450.596,98 USD 73.26%
i alt 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 opdeler et udtryk, der opsummerer tabellen Saleskolonneværdien Sales Amount (i filterkonteksten) med det samme udtryk i en ændret filterkontekst. Det er den CALCULATE funktion, der ændrer filterkonteksten ved hjælp af funktionen REMOVEFILTERS, som er en filterændringsfunktion. Den fjerner filtre fra tabellen Sales Orderkolonnen Channel.

Følgende Definition af beregnet kolonne for kunde tabel klassificerer kunder i en loyalitetsklasse. Det er et meget simpelt scenarie: Når kundens indtægt er mindre end 2.500 USD, klassificeres de som Low; Ellers er de High.

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 tabelkolonnerne Customer undtagen kolonnen CustomerKey.

filterkontekstrækkekontekstCALCULATETABLE funktionfilterfunktioner