Compartir a través de


CALCULATE

Se aplica a:columna Calculadatabla calculadaMedidacálculo visual

Evalúa una expresión en un contexto de filtro modificado.

Nota

También hay la función CALCULATETABLE. Realiza exactamente la misma funcionalidad, salvo que modifica el contexto de filtro aplicado a una expresión que devuelve un objeto de tabla .

Sintaxis

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

Parámetros

Término Definición
expression Expresión que se va a evaluar.
filter1, filter2,… (Opcional) Expresiones booleanas o expresiones de tabla que definen filtros o funciones modificadores de filtro.

La expresión usada como primer parámetro es básicamente la misma que una medida.

Los filtros pueden ser:

  • Expresiones de filtro booleanas
  • Expresiones de filtro de tabla
  • Funciones de modificación de filtros

Cuando hay varios filtros, se pueden evaluar mediante el AND (&&) operador lógico, lo que significa que todas las condiciones deben ser TRUEo mediante el operador lógico OR (||), lo que significa que cualquiera de las condiciones puede ser true.

Expresiones de filtro booleanas

Un filtro de expresión booleana es una expresión que se evalúa como TRUE o FALSE. Hay varias reglas que deben cumplir:

  • Pueden hacer referencia a columnas de una sola tabla.
  • No pueden hacer referencia a medidas.
  • No pueden usar una función CALCULATE anidada.

A partir de la versión de septiembre de 2021 de Power BI Desktop, también se aplica lo siguiente:

  • No pueden usar funciones que examinan o devuelven una tabla a menos que se pasen como argumentos a las funciones de agregación.
  • pueden contener una función de agregación que devuelve un valor escalar. Por ejemplo
    Total sales on the last selected date =
    CALCULATE (
        SUM ( Sales[Sales Amount] ),
        'Sales'[OrderDateKey] = MAX ( 'Sales'[OrderDateKey] )
    )
    

Expresión de filtro de tabla

Un filtro de expresión de tabla aplica un objeto de tabla como filtro. Podría ser una referencia a una tabla de modelo, pero es más probable que sea una función que devuelva un objeto table. Puede usar la función FILTER para aplicar condiciones de filtro complejas, incluidas las que no se pueden definir mediante una expresión de filtro booleana.

Funciones modificadores de filtro

Las funciones modificadores de filtro permiten hacer más que simplemente agregar filtros. Proporcionan un control adicional al modificar el contexto de filtro.

Función Propósito
REMOVEFILTERS Quite todos los filtros o filtros de una o varias columnas de una tabla o de todas las columnas de una sola tabla.
ALL 1, ALLEXCEPT, ALLNOBLANKROW Quite filtros de una o varias columnas o de todas las columnas de una sola tabla.
KEEPFILTERS Agregue filtro sin quitar filtros existentes en las mismas columnas.
USERELATIONSHIP Interactuar con una relación inactiva entre las columnas relacionadas, en cuyo caso la relación activa se volverá inactiva automáticamente.
CROSSFILTER Modifique la dirección del filtro (de ambos a único o de uno a ambos) o deshabilite una relación.

1 La función ALL y sus variantes se comportan como modificadores de filtro y como funciones que devuelven objetos de tabla. Si la función REMOVEFILTERS es compatible con la herramienta, es mejor usarlo para quitar filtros.

Valor devuelto

Valor que es el resultado de la expresión.

Observaciones

  • Cuando se proporcionan expresiones de filtro, la función CALCULATE modifica el contexto de filtro para evaluar la expresión. Para cada expresión de filtro, hay dos resultados estándar posibles cuando la expresión de filtro no está ajustada en la función KEEPFILTERS:

    • Si las columnas (o tablas) no están en el contexto de filtro, se agregarán nuevos filtros al contexto de filtro para evaluar la expresión.
    • Si las columnas (o tablas) ya están en el contexto de filtro, los filtros existentes se sobrescribirán mediante los nuevos filtros para evaluar la expresión CALCULATE.
  • La función CALCULATE usada sin filtros consigue un requisito específico. Realiza la transición del contexto de fila al contexto de filtro. Es necesario cuando una expresión (no una medida de modelo) que resume los datos del modelo debe evaluarse en el contexto de fila. Este escenario puede ocurrir en una fórmula de columna calculada o cuando se evalúa una expresión en una función de iterador. Tenga en cuenta que cuando se usa una medida de modelo en el contexto de fila, la transición de contexto es automática.

  • Esta función no se admite para su uso en el modo DirectQuery cuando se usa en columnas calculadas o reglas de seguridad de nivel de fila (RLS).

Ejemplos

La siguiente definición de medida Sales tabla genera un resultado de ingresos, pero solo para los productos que tienen el color azul.

Los ejemplos de este artículo se pueden usar con el modelo de Power BI Desktop de Adventure Works 2020 de ejemplo. Para obtener el modelo, consulte DAX modelo de ejemplo.

Blue Revenue =
CALCULATE(
    SUM(Sales[Sales Amount]),
    'Product'[Color] = "Blue"
)
Categoría Importe de ventas Ingresos azules
Accesorios $1,272,057,89 $165,406.62
Bicicletas $94,620,526.21 $8,374,313.88
Ropa $2,117,613.45 $259,488.37
Componentes $11,799,076,66 $803,642.10
total de $109.809.274.20 $9.602.850.97

La función evalúa la suma de la tabla Sales Sales Amount en un contexto de filtro modificado. Se agrega un nuevo filtro a la tabla Product columna Color, o bien, el filtro sobrescribe cualquier filtro que ya se haya aplicado a la columna.

La siguiente definición de medida Sales tabla genera una proporción de ventas por encima de las ventas de todos los canales de ventas.

Canal Importe de ventas Ingresos % canal total
Internet $29,358,677.22 26.74%
Revendedor $80,450,596.98 73.26%
total de $109.809.274.20 100,00%
Revenue % Total Channel =
DIVIDE(
    SUM(Sales[Sales Amount]),
    CALCULATE(
        SUM(Sales[Sales Amount]),
        REMOVEFILTERS('Sales Order'[Channel])
    )
)

La función DIVIDE divide una expresión que suma la tabla SalesSales Amount valor de columna (en el contexto de filtro) por la misma expresión en un contexto de filtro modificado. Es la función CALCULATE que modifica el contexto de filtro mediante la función REMOVEFILTERS, que es una función modificadora de filtro. Quita los filtros de la tabla Sales Order columna Channel.

La siguiente Customer definición de columna calculada clasifica a los clientes en una clase de fidelidad. Es un escenario muy sencillo: cuando los ingresos generados por el cliente son inferiores a 2500 USD, se clasifican como baja; de lo contrario, se alto.

Customer Segment =
IF(
    CALCULATE(SUM(Sales[Sales Amount]), ALLEXCEPT(Customer, Customer[CustomerKey])) < 2500,
    "Low",
    "High"
)

En este ejemplo, el contexto de fila se convierte en el contexto de filtro. Se conoce como transición de contexto. La función quita los filtros de todas las columnas de tabla Customer , excepto la columna customerKey de .

contexto de filtrofunciónCALCULATETABLE funciónFilter