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, chicos
A continuación se muestran mis datos
ID Nombre Estado de la planta
1 | A | abecedario | Aprobado |
1 | A | Def | PendienteRevisión |
1 | A | grabar | Aprobar - ACD |
1 | A | jkl | Corriente de aire |
1 | A | Adf | Rechazado |
1 | A | desde 100.0 | Rechazado |
2 | B | abecedario | Aprobado |
2 | B | Def | Aprobado |
2 | B | grabar | Aprobar - ACD |
2 | B | jkl | Aprobar - ACD |
2 | B | Adf | Aprobar - ACD |
2 | B | desde 100.0 | Aprobar - ACD |
3 | C | abecedario | NULO |
3 | C | Def | NULO |
3 | C | grabar | NULO |
3 | C | jkl | Corriente de aire |
3 | C | Adf | Corriente de aire |
3 | C | desde 100.0 | Corriente de aire |
4 | D | abecedario | PendienteRevisión |
4 | D | Def | PendienteRevisión |
4 | D | grabar | PendienteRevisión |
4 | D | jkl | PendienteRevisión |
4 | D | Adf | PendienteRevisión |
4 | D | desde 100.0 | PendienteRevisión |
Ahora estoy tratando de crear una nueva columna con algunas condiciones. A continuación se presentan 4 condiciones para la nueva columna
Si un ID tiene:
Status = "NULL" y "DRAFT" o cualquiera de ellos, entonces el valor será "Yet To Start"
Estado = "Aprobado" (o) "Aprobar - ACD/Rechazado" (o) Ambos entonces el valor será "Completado"
Estado = "Pendiente de revisión" y el valor será "En curso"
Si el estado es mixto para un ID como (ID 1, por ejemplo)
"Aprobado" y "Pendientereview" y "Borrador" y "NULL" entonces el valor será "En curso"
Resultado esperado:
Cuando intenté usar && Symbol para las condiciones, obtengo valores en blanco
Nota: Necesito esto en columna en lugar de medir porque usaré la misma columna para la leyenda en el gráfico de donas.
Adjuntar pbix de muestra para referencia
https://drive.google.com/file/d/1WX-qYpr_R4Xg1VKjlo6wdmAEa3Zzp_NC/view?usp=sharing
¡Por favor, ayúdame en esto!
¡Gracias de antemano!
@parry2k @amitchandak @Jihwan_Kim
Solved! Go to Solution.
@HemanthV , Pruebe una nueva columna como ejemplo
Nueva columna =
var _1 = countx(filter(Table, [ID] = earlier([ID]) && [Status]= "NULL"),[Status])
var _2 = countx(filter(Table, [ID] = earlier([ID]) && [Status]= "Borrador"),[Status])
var _3 = countx(filter(Table, [ID] = earlier([ID]) && [Status] en {"Aprobado", "Aprobado - ACD/Rechazado"}),[Estado])
var _4 = countx(filter(Table, [ID] = earlier([ID]) && [Status] en {"Pending Review"}),[Status])
devolución
Interruptor ( True() ,
not(isblank(_1)) && not(isblank(_2)) , "Yet To Start",
not(isblank(_3)) , "Completado" ,
not(isblank(_4)) ,"En curso"
)
por qué el ID 1 está en curso, no vi NULL del ID 1.
tal vez puedas probar esto
Column =
VAR _null=maxx(FILTER(Table1,Table1[ID]=EARLIER(Table1[ID])&&Table1[Status]="NULL"),Table1[Status])
var _draft=maxx(FILTER(Table1,Table1[ID]=EARLIER(Table1[ID])&&Table1[Status]="Draft"),Table1[Status])
var _approve=maxx(FILTER(Table1,Table1[ID]=EARLIER(Table1[ID])&&Table1[Status]="Approved"),Table1[Status])
var _acd=maxx(FILTER(Table1,Table1[ID]=EARLIER(Table1[ID])&&Table1[Status]="Approve - ACD"),Table1[Status])
var _pending=maxx(FILTER(Table1,Table1[ID]=EARLIER(Table1[ID])&&Table1[Status]="PendingReview"),Table1[Status])
return if(_approve<>""&&_pending<>""&&_null<>""&&_draft<>"","In progess",if(_null<>""||_draft<>"","Yet to start",if(_approve<>""||_acd<>"","Completed",if(_pending<>"","In progress"))))
por qué el ID 1 está en curso, no vi NULL del ID 1.
tal vez puedas probar esto
Column =
VAR _null=maxx(FILTER(Table1,Table1[ID]=EARLIER(Table1[ID])&&Table1[Status]="NULL"),Table1[Status])
var _draft=maxx(FILTER(Table1,Table1[ID]=EARLIER(Table1[ID])&&Table1[Status]="Draft"),Table1[Status])
var _approve=maxx(FILTER(Table1,Table1[ID]=EARLIER(Table1[ID])&&Table1[Status]="Approved"),Table1[Status])
var _acd=maxx(FILTER(Table1,Table1[ID]=EARLIER(Table1[ID])&&Table1[Status]="Approve - ACD"),Table1[Status])
var _pending=maxx(FILTER(Table1,Table1[ID]=EARLIER(Table1[ID])&&Table1[Status]="PendingReview"),Table1[Status])
return if(_approve<>""&&_pending<>""&&_null<>""&&_draft<>"","In progess",if(_null<>""||_draft<>"","Yet to start",if(_approve<>""||_acd<>"","Completed",if(_pending<>"","In progress"))))
ID1 está en curso porque se ha mezclado con todos los estados
En los datos de muestra no tiene null pero tiene 3 condiciones restantes
su descripción enumera el estado 4, luego el resultado está en progreso. Entonces, si una identificación tiene tres condiciones, ¿entonces el resultado está en progreso?
Sí, ¡muchas gracias por ayudarme! Modifiqué las condiciones que enviaste y obtuve el resultado deseado.
¡Muchas gracias!
De nada
@HemanthV , Pruebe una nueva columna como ejemplo
Nueva columna =
var _1 = countx(filter(Table, [ID] = earlier([ID]) && [Status]= "NULL"),[Status])
var _2 = countx(filter(Table, [ID] = earlier([ID]) && [Status]= "Borrador"),[Status])
var _3 = countx(filter(Table, [ID] = earlier([ID]) && [Status] en {"Aprobado", "Aprobado - ACD/Rechazado"}),[Estado])
var _4 = countx(filter(Table, [ID] = earlier([ID]) && [Status] en {"Pending Review"}),[Status])
devolución
Interruptor ( True() ,
not(isblank(_1)) && not(isblank(_2)) , "Yet To Start",
not(isblank(_3)) , "Completado" ,
not(isblank(_4)) ,"En curso"
)
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 |