Join us at FabCon Atlanta from March 16 - 20, 2026, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.
Register now!The Power BI Data Visualization World Championships is back! Get ahead of the game and start preparing now! Learn more
Solved! Go to Solution.
Hi @Sadab ,
We can try to use the following queries to meet your requirement:
(InitialDate as datetime, FinalDate as datetime, optional Holidays as list ) as number =>
let
HolidayDates = if Holidays=null then {null} else List.Select(Holidays, each _ is date ),
DaysBetweenDates = Duration.Days(DateTime.Date(FinalDate)-DateTime.Date(InitialDate)),
DaysList = List.Dates(List.Min({DateTime.Date(InitialDate),DateTime.Date(FinalDate)}),Number.Abs(DaysBetweenDates)+1, Duration.From(1)),
WeekDaysList = List.Select(DaysList, each (Date.DayOfWeek(_, Day.Monday) < 5) ),
WeekDaysNoHolidaysList = List.RemoveItems(WeekDaysList, HolidayDates ),
WorkingDays = (if DaysBetweenDates < 0 then -1 else 1) * List.Count(WeekDaysNoHolidaysList),
ActualWorkingDays = WorkingDays
- (if List.Contains(WeekDaysNoHolidaysList,DateTime.Date(InitialDate)) then Duration.Seconds(InitialDate - DateTime.From(DateTime.Date(InitialDate)))/(3600*24) else 0)
- (if List.Contains(WeekDaysNoHolidaysList,DateTime.Date(FinalDate)) then Duration.Seconds(Date.AddDays(DateTime.From(DateTime.Date(FinalDate)),1) - FinalDate)/(3600*24) else 0)
in
ActualWorkingDays
Best regards,
Hi @Sadab ,
We can try to use the following queries to meet your requirement:
(InitialDate as datetime, FinalDate as datetime, optional Holidays as list ) as number =>
let
HolidayDates = if Holidays=null then {null} else List.Select(Holidays, each _ is date ),
DaysBetweenDates = Duration.Days(DateTime.Date(FinalDate)-DateTime.Date(InitialDate)),
DaysList = List.Dates(List.Min({DateTime.Date(InitialDate),DateTime.Date(FinalDate)}),Number.Abs(DaysBetweenDates)+1, Duration.From(1)),
WeekDaysList = List.Select(DaysList, each (Date.DayOfWeek(_, Day.Monday) < 5) ),
WeekDaysNoHolidaysList = List.RemoveItems(WeekDaysList, HolidayDates ),
WorkingDays = (if DaysBetweenDates < 0 then -1 else 1) * List.Count(WeekDaysNoHolidaysList),
ActualWorkingDays = WorkingDays
- (if List.Contains(WeekDaysNoHolidaysList,DateTime.Date(InitialDate)) then Duration.Seconds(InitialDate - DateTime.From(DateTime.Date(InitialDate)))/(3600*24) else 0)
- (if List.Contains(WeekDaysNoHolidaysList,DateTime.Date(FinalDate)) then Duration.Seconds(Date.AddDays(DateTime.From(DateTime.Date(FinalDate)),1) - FinalDate)/(3600*24) else 0)
in
ActualWorkingDays
Best regards,
The Power BI Data Visualization World Championships is back! Get ahead of the game and start preparing now!
| User | Count |
|---|---|
| 19 | |
| 10 | |
| 9 | |
| 7 | |
| 6 |