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

Don'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.

Reply
madman12
Frequent Visitor

Split Start-End timestamp Rows into per minute rows

I have one table such as:

 

PersonLocationStartEnd
Person ALocA29/04/2024 13:0029/04/2024 15:57
Person ALocR25/04/2024 18:0029/04/2024 17:14
Person GLocA28/04/2024 21:0028/04/2024 21:02

 

I want to split rows into minute granularity rows, take last row above as example the result would be:

 

PersonLocationStartEndMinute
Person GLocA28/04/2024 21:0028/04/2024 21:0228/04/2024 21:00
Person GLocA28/04/2024 21:0028/04/2024 21:02

28/04/2024 21:01

Person GLocA28/04/2024 21:0028/04/2024 21:0228/04/2024 21:02

 

Its like a join,except instead of it being a exact match join to one of the timestamps its a between join with a date/time table that holds a row for each minute of the day. At least thats how I'm interpreting it.

 

I can do the splitting into minute granularity rows in SQL to allow the usual exact match of a join in PBI to work (join on between) however the more people, locations and dates covered the larger the extract so its limited in scale.

 

Wondering if powerbi would be able to handle that part so SQL would only need to get a row for each whole period as shown in first table.

1 ACCEPTED SOLUTION
Anonymous
Not applicable

Hi @madman12 ,

Below is my table:

vxiandatmsft_0-1714441073090.png

This situation can be realised using the m-language:

You can create a custom column:

List.Transform(
    List.DateTimes(
        [Start], 
        Duration.TotalMinutes([End] - [Start]) + 1, 
        #duration(0, 0, 1, 0)
    ), 
    each DateTime.ToText(_, "dd/MM/yyyy HH:mm")
))

The final output is shown in the following figure:

vxiandatmsft_1-1714441187301.pngvxiandatmsft_2-1714441198580.pngvxiandatmsft_3-1714441208915.pngvxiandatmsft_4-1714441218683.png

Best Regards,

Xianda Tang

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

1 REPLY 1
Anonymous
Not applicable

Hi @madman12 ,

Below is my table:

vxiandatmsft_0-1714441073090.png

This situation can be realised using the m-language:

You can create a custom column:

List.Transform(
    List.DateTimes(
        [Start], 
        Duration.TotalMinutes([End] - [Start]) + 1, 
        #duration(0, 0, 1, 0)
    ), 
    each DateTime.ToText(_, "dd/MM/yyyy HH:mm")
))

The final output is shown in the following figure:

vxiandatmsft_1-1714441187301.pngvxiandatmsft_2-1714441198580.pngvxiandatmsft_3-1714441208915.pngvxiandatmsft_4-1714441218683.png

Best Regards,

Xianda Tang

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

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!

Jan25PBI_Carousel

Power BI Monthly Update - January 2025

Check out the January 2025 Power BI update to learn about new features in Reporting, Modeling, and Data Connectivity.

December 2024

A Year in Review - December 2024

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