Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Be one of the first to start using Fabric Databases. View on-demand sessions with database experts and the Microsoft product team to learn just how easy it is to get started. Watch now

Reply
Syndicate_Admin
Administrator
Administrator

Calcular el porcentaje de asignación en función de los días dentro de un rango

Hola a todos

Quiero crear una visualización de tabla, con el nombre de cada empleado y el porcentaje de asignación por mes (dentro del rango de fecha de inicio y fecha de finalización).

Tabla de salida con – Nombre del empleado, Mes y porcentaje de asignación à capacidad para dividir por mes.

Además, si es posible, vea la asignación por año o YTD

Tengo tres tablas en mi modelo –

Dim_date – columnas de fecha

Empleado de Dim – Nombre, país y primera fecha de trabajo,

Fact_project asignación – empname, fecha de inicio, fecha de finalización, asignación perc( valor de 0.1 a 1)

He adjuntado datos de muestra como referencia, por favor sugiera.

MartinAa_0-1675410712026.png

Así que como resultado -

empnamemesasignaciónPerc
RocosoDic 202250%
RocosoEnero 2022100%
RocosoFebrero de 2022100%

Dic 2022 - 50% Porque solo se asignan 15 días en ese mes.
Y así sucesivamente..!!

..

Gracias.

-Avión

Hola - @wdx223_Daniel . Realmente apreciaría si pudieras ayudarme en esto..!!

3 REPLIES 3
Syndicate_Admin
Administrator
Administrator

@MartinAa ,

De acuerdo con su descripción, aquí están mis pasos que puede seguir como solución.

(1) Mis datos de prueba son los mismos que los suyos.

(2) Podemos crear una tabla.

Output = 
var _a = ADDCOLUMNS(CALENDAR(MIN('Table'[start_date]),MAX('Table'[end_date])),"Month",FORMAT([Date],"MMM YYYY"))
var _b = CROSSJOIN(VALUES('Table'[empname]),_a)
var _c = ADDCOLUMNS(_b,"FFlag",SUMX(ADDCOLUMNS(FILTER('Table',[empname]=EARLIER('Table'[empname])),"Flag",IF([Date]>=[start_date]&&[Date]<=[end_date],1,0)),[Flag]))
var _d = SUMMARIZE(_c,'Table'[empname],[Month],"allocationPerc",DIVIDE(COUNTX(FILTER(_c,[empname]=EARLIER('Table'[empname])&&[Month]=EARLIER([Month])&&[FFlag]<>0),[FFlag]),MAXX(FILTER(_a,[Month]=EARLIER([Month])),DAY(EOMONTH([Date],0)))))
return FILTER(_d,[allocationPerc]<>0)

(3) Entonces el resultado es el siguiente.

vtangjiemsft_0-1675671137855.png

Saludos

Neeko Tang

Si esta publicación ayuda, considere Aceptarlo como la solución para ayudar a los otros miembros a encontrarlo más rápidamente.

Muchas gracias @v-tangjie-msft ..!!

Syndicate_Admin
Administrator
Administrator

Proporcione datos de muestra que cubran su problema o pregunta por completo.
https://community.powerbi.com/t5/Community-Blog/How-to-provide-sample-data-in-the-Power-BI-Forum/ba-...
Muestre el resultado esperado en función de los datos de muestra que proporcionó.

https://community.powerbi.com/t5/Desktop/How-to-Get-Your-Question-Answered-Quickly/m-p/1447523

Helpful resources

Announcements
Las Vegas 2025

Join us at the Microsoft Fabric Community Conference

March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!

Dec Fabric Community Survey

We want your feedback!

Your insights matter. That’s why we created a quick survey to learn about your experience finding answers to technical questions.

ArunFabCon

Microsoft Fabric Community Conference 2025

Arun Ulag shares exciting details about the Microsoft Fabric Conference 2025, which will be held in Las Vegas, NV.

December 2024

A Year in Review - December 2024

Find out what content was popular in the Fabric community during 2024.

Top Solution Authors
Top Kudoed Authors