Register now to learn Fabric in free live sessions led by the best Microsoft experts. From Apr 16 to May 9, in English and Spanish.
Hola;
Necesito su amable apoyo para el siguiente número pls :
tengo tabla como se muestra a continuación, el último colum marcado en amarillo que quiero crear en mitabla. Necesito fórmula dax para la columna, no para medir.
Así que pls permítanme explicar lo que es esta tabla y en qué reglas necesito columna amarilla.
en esta tabla hay materiales que se indexan como grupo para cada uno de ellos, hay cantidades de solicitud y fechas de solicitud, cantidades de entrega y fechas de entrega,
La columna "cantidad abierta" muestra: cantidad de solicitud -cantidad de entrega
La columna "statu" muestra que si todos los materiales entregados o no, si todo el material entregado se cierra, si no está abierto.
Me gustaría encontrar si hay violación durante la entrega de cantidades. Así que reglas como esa :
para hacer su cálculo más fácil soy sharig con usted sobresale ource como se muestra a continuación:
https://drive.google.com/file/d/1252yy235azu94tCWCUDAbjI3f1FPEqvy/view?usp=sharing
Espero que esté claro gracias de antemano por su amable ayuda
Solved! Go to Solution.
Hey @erhan_79 ,
Asumo que esta instrucción DAX permite crear una columna calculada que devuelve lo que está buscando:
violation =
var __Material = 'Table'[Material]
var __Index = 'Table'[Index]
var __Status = 'Table'[Status]
var __DeliveryDate = 'Table'[Delivery Date]
var doSucceedingDeliveriesExist =
IF( __Status = "Open"
, IF(
CALCULATE(
MAX( 'Table'[Delivery Quantity] )
, FILTER(
ALL( 'Table')
, 'Table'[Material] = __Material && 'Table'[Index] > __Index
)
) > 0
, "Violation"
, BLANK()
)
)
var doOpenPreceedingDeliveriesExist =
IF( __Status = "Closed"
, IF(
CALCULATE(
MIN( 'Table'[Delivery Date] )
, FILTER(
ALL( 'Table')
, 'Table'[Material] = __Material && 'Table'[Index] > __Index
)
) <= __DeliveryDate
, "Violation"
, BLANK()
)
)
return
IF( doSucceedingDeliveriesExist = "Violation" || doOpenPreceedingDeliveriesExist = "Violation"
, "Violation"
, BLANK()
)
Aquí hay una captura de pantalla del resultado, tenga en cuenta que llamo a la violación de columna:
Con suerte, esto proporciona lo que está buscando.
saludos
Tom
Hey @erhan_79 ,
Asumo que esta instrucción DAX permite crear una columna calculada que devuelve lo que está buscando:
violation =
var __Material = 'Table'[Material]
var __Index = 'Table'[Index]
var __Status = 'Table'[Status]
var __DeliveryDate = 'Table'[Delivery Date]
var doSucceedingDeliveriesExist =
IF( __Status = "Open"
, IF(
CALCULATE(
MAX( 'Table'[Delivery Quantity] )
, FILTER(
ALL( 'Table')
, 'Table'[Material] = __Material && 'Table'[Index] > __Index
)
) > 0
, "Violation"
, BLANK()
)
)
var doOpenPreceedingDeliveriesExist =
IF( __Status = "Closed"
, IF(
CALCULATE(
MIN( 'Table'[Delivery Date] )
, FILTER(
ALL( 'Table')
, 'Table'[Material] = __Material && 'Table'[Index] > __Index
)
) <= __DeliveryDate
, "Violation"
, BLANK()
)
)
return
IF( doSucceedingDeliveriesExist = "Violation" || doOpenPreceedingDeliveriesExist = "Violation"
, "Violation"
, BLANK()
)
Aquí hay una captura de pantalla del resultado, tenga en cuenta que llamo a la violación de columna:
Con suerte, esto proporciona lo que está buscando.
saludos
Tom
Covering the world! 9:00-10:30 AM Sydney, 4:00-5:30 PM CET (Paris/Berlin), 7:00-8:30 PM Mexico City
Check out the April 2024 Power BI update to learn about new features.
User | Count |
---|---|
2 | |
1 | |
1 | |
1 | |
1 |
User | Count |
---|---|
2 | |
2 | |
2 | |
1 | |
1 |