Check your eligibility for this 50% exam voucher offer and join us for free live learning sessions to get prepared for Exam DP-700.
Get StartedDon't miss out! 2025 Microsoft Fabric Community Conference, March 31 - April 2, Las Vegas, Nevada. Use code MSCUST for a $150 discount. Prices go up February 11th. Register now.
Hi
I'm trying to replicate the following excel table in PowerBI:
The table displays the number of absent staff per month in the past 24 months.
The table uses the TODAY() and EOMONTH() excel formulae to generate a 'Month', 'End Of Month' and 'Start Of Month' column.
Then using the following formula it counts how many staff were absent (at any point) in each month:
Where Absence_Data2 is my source data of a list of staff with a start and end date for each staff absence period:
I've tried making a DateTable query in PowerBI to generate a 'Month', 'End Of Month' and 'Start Of Month' column in a powerBI matrix:
I've connected my DateTable query to the Absence_Data2 query as follows:
From here I'm not sure how to add an 'Absence Occurences' column to my matrix to count how many staff were absent in each month.
i.e. count how many absence date ranges of my Absence_Data2 query have dates that fall within the date range of each month of my DateTable query.
The source data and powerBI files are available via the follwoing link:
Absence_Occurences_AO_Sample_v5.xlsx
Absence_Dashboard_Sample_v1.pbix
Any help or guidance would be much appreciated!
Solved! Go to Solution.
Hi, @JFarq
Please try formula like:
calculated column:
Absence Occurences per person per month =
CALCULATE (
COUNT ( Absence_Data2[Start Date] ),
ALLEXCEPT (
Absence_Data2,
Absence_Data2[Start Date].[Month],
Absence_Data2[Start Date].[Year],
Absence_Data2[Forename And Surname]
)
)
Measure:
count of absence date =
CALCULATE (
COUNTROWS ( Absence_Data2 ),
FILTER (
Absence_Data2,
Absence_Data2[Start Date] >= MAX ( 'Calendar (UK?)'[StartOfMonth] )
&& Absence_Data2[Start Date] <= MAX ( 'Calendar (UK?)'[EndOfMonth] )
)
) + 0
(need change the data type of 'Calendar (UK?)'[StartOfMonth], 'Calendar (UK?)'[EndOfMonth] from 'Text' to 'Date')
Best Regards,
Community Support Team _ Eason
Hi, @JFarq
Please try formula like:
calculated column:
Absence Occurences per person per month =
CALCULATE (
COUNT ( Absence_Data2[Start Date] ),
ALLEXCEPT (
Absence_Data2,
Absence_Data2[Start Date].[Month],
Absence_Data2[Start Date].[Year],
Absence_Data2[Forename And Surname]
)
)
Measure:
count of absence date =
CALCULATE (
COUNTROWS ( Absence_Data2 ),
FILTER (
Absence_Data2,
Absence_Data2[Start Date] >= MAX ( 'Calendar (UK?)'[StartOfMonth] )
&& Absence_Data2[Start Date] <= MAX ( 'Calendar (UK?)'[EndOfMonth] )
)
) + 0
(need change the data type of 'Calendar (UK?)'[StartOfMonth], 'Calendar (UK?)'[EndOfMonth] from 'Text' to 'Date')
Best Regards,
Community Support Team _ Eason
Thank you very much v-easonf-msft.
Your measure works for me.
I just had to write it out with 'MANUAL End Date' in first line of the second argument of the FILTER() function:
count of absence date =
CALCULATE (
COUNTROWS ( Absence_Data2 ),
FILTER (
Absence_Data2,
Absence_Data2[MANUAL End Date] >= MAX ( 'Calendar (UK?)'[StartOfMonth] )
&& Absence_Data2[Start Date] <= MAX ( 'Calendar (UK?)'[EndOfMonth] )
)
) + 0
To get:
In Power BI it is best practice to use a calendar table.
All reports use dates so this is really important skill for you to learn
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount! Prices go up Feb. 11th.
Check out the January 2025 Power BI update to learn about new features in Reporting, Modeling, and Data Connectivity.
User | Count |
---|---|
143 | |
75 | |
64 | |
52 | |
47 |
User | Count |
---|---|
218 | |
87 | |
71 | |
63 | |
60 |