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

The ultimate Microsoft Fabric, Power BI, Azure AI & SQL learning event! Join us in Las Vegas from March 26-28, 2024. Use code MSCUST for a $100 discount. Register Now

Reply
M0n5ta09
Helper I
Helper I

Calculate difference in times excluding times between a range

Hi All,

 

I'm trying to calculate the difference in times from datetimestamp columns (Start & End) but need to exclude times between 2 times and the result is in hours and minutes.

In the example below, the period to exclude is between 10PM to 4AM and is based on Start and End slicers i.e. only calculate the times from 4AM to 10PM.

 

ScenarioStartEndEnd - StartCorrect Time
Fault 1 - Start >= 4AM & End < 10PM10/03/2022 06:2510/03/2022 09:1502:50 02:50
Fault 2 - Start < 4AM & End < 10PM11/03/2022 03:0011/03/2022 10:3007:3006:30
Fault 3 - Start >= 4AM & End >= 10PM12/03/2022 21:1012/03/2022 23:3002:2000:50
Fault 4 - Start >= 10PM & End < 4AM (before midnight)13/03/2022 23:0013/03/2022 23:3000:3000:00
Fault 5 - Start >= 10PM & End < 4AM (end +1 day)14/03/2022 22:3015/03/2022 02:3004:0000:00
Fault 6 - Start >=10PM & End >= 4AM15/03/2022 22:3016/03/2022 04:3006:0000:30
Fault 7 - Start < 10PM & End >= 4AM (end +2 days)16/03/2022 19:0018/03/2022 05:0010:0022:00

 

I've tried creating calculated columns to adjust the Start and End times which kind of works but not if the End is more than 1 day.

 

I have this Excel formula which kind of works;

 

=IF(End<Start,"Check Value", MAX(0,TIME(22,0,0)-MAX(MOD(Start,1),TIME(4,0,0)))+MAX(0,MIN(MOD(End,1),TIME(22,0,0))-TIME(4,0,0))+(INT(End)-INT(Start)-1)*TIME(18,0,0))

 

Many thanks.

1 ACCEPTED SOLUTION

Hi @M0n5ta09 ,

 

Yes, it is easier to work in minutes.

 

When I converted minutes to time, I made some mistakes. Please try this code.

 

Column =
VAR _a =
    GENERATESERIES ( [Start], [End], TIME ( 0, 1, 0 ) )
VAR _filter =
    FILTER (
        _a,
        TIMEVALUE ( [Value] ) > TIME ( 3, 59, 59 )
            && TIMEVALUE ( [Value] ) <= TIME ( 21, 59, 59 )
    )
VAR _m =
    COUNTROWS ( _filter )
RETURN
    ROUNDDOWN ( _m / 60, 0 ) & ":"
        & MOD ( _m, 60 )

 

Best Regards

Community Support Team _ chenwu zhu

 

If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

View solution in original post

4 REPLIES 4
v-chenwuz-msft
Community Support
Community Support

Hi @M0n5ta09 ,

 

Please try this expression to do it:

 

Column =
VAR _a =
    GENERATESERIES ( [Start], [End], TIME ( 0, 1, 0 ) )
VAR _filter =
    FILTER (
        _a,
        TIMEVALUE ( [Value] ) > TIME ( 3, 59, 59 )
            && TIMEVALUE ( [Value] ) <= TIME ( 21, 59, 59 )
    )
RETURN
    TIME ( 0, COUNTROWS ( _filter ), 0 )

 

Result:

vchenwuzmsft_0-1652338359657.png

 

Pbix in the end you can refer.

Best Regards

Community Support Team _ chenwu zhu

 

If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

Thank you. Apologies for the delay reply.

 

This works for a majority but not with these Start and End. I'm guessing because the hours are over 24;

 

FaultStartEndColumn
130/04/2022 10:58:04 01/05/2022 21:20:004:22:00
201/05/2022 13:00:0003/05/2022 19:30:0018:30:00

 

Fault 1:

10:58 to 22:00 = 11:02 or 662 minutes

04:00 to 21:20 = 17:20 or 1040 minutes

Result should be 11:02 + 17:20 = 18:22 or 1102 minutes

 

Fault 2:

01/05/2022 13:00 to 22:00 = 9:00 or 540 minutes

02/05/2022 04:00 to 22:00 = 18:00 or 1080 minutes

03/05/2022 04:00 to 19:30  = 15:30 or 930 minutes

Result should be 9:00 + 18:00 + 15:30 = 42:30:00 or 2550 minutes

 

Is it easier to work in minutes and convert to time afterwards?

Hi @M0n5ta09 ,

 

Yes, it is easier to work in minutes.

 

When I converted minutes to time, I made some mistakes. Please try this code.

 

Column =
VAR _a =
    GENERATESERIES ( [Start], [End], TIME ( 0, 1, 0 ) )
VAR _filter =
    FILTER (
        _a,
        TIMEVALUE ( [Value] ) > TIME ( 3, 59, 59 )
            && TIMEVALUE ( [Value] ) <= TIME ( 21, 59, 59 )
    )
VAR _m =
    COUNTROWS ( _filter )
RETURN
    ROUNDDOWN ( _m / 60, 0 ) & ":"
        & MOD ( _m, 60 )

 

Best Regards

Community Support Team _ chenwu zhu

 

If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

Thank so much @v-chenwuz-msft 

 

Works perfectly 👍

Helpful resources

Announcements
Fabric Community Conference

Microsoft Fabric Community Conference

Join us at our first-ever Microsoft Fabric Community Conference, March 26-28, 2024 in Las Vegas with 100+ sessions by community experts and Microsoft engineering.

Fabric Career Hub

Microsoft Fabric Career Hub

Explore career paths and learn resources in Fabric.

Fabric Partner Community

Microsoft Fabric Partner Community

Engage with the Fabric engineering team, hear of product updates, business opportunities, and resources in the Fabric Partner Community.

Power BI Header Change

Power BI Header Update

Read about the exciting updates for the Power BI forum.