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
Anonymous
Not applicable

Most recent calculation

Dear all,

I am looking for a calculation which does the following:

If the STACK is the same and the TYPE is the same and the DATE is the same, calculate the MOST_RECENT_TIME_STAMP.

In below example the outcome is is 23-10-2020 08:00.

Thanks!

John

 

stackpositiontypedatetime_stampmost_recent_time_Stamp
WP2WP2.12Waiting Estimate23-10-202023-10-2020 08:0023-10-2020 08:00
WP2WP2.11Waiting Estimate23-10-202023-10-2020 08:0023-10-2020 08:00
WP2WP2.10Waiting Estimate23-10-202023-10-2020 07:5923-10-2020 08:00
WP2WP2.09Waiting Estimate23-10-202023-10-2020 07:5923-10-2020 08:00
WP2WP2.08Waiting Estimate23-10-202023-10-2020 07:5923-10-2020 08:00
WP2WP2.07Waiting Estimate23-10-202023-10-2020 07:5823-10-2020 08:00
WP2WP2.06Waiting Estimate23-10-202023-10-2020 07:5823-10-2020 08:00
WP2WP2.05Waiting Estimate23-10-202023-10-2020 07:5823-10-2020 08:00
WP2WP2.04Waiting Estimate23-10-202023-10-2020 07:5723-10-2020 08:00
WP2WP2.03Waiting Estimate23-10-202023-10-2020 07:5723-10-2020 08:00
WP2WP2.02Waiting Estimate23-10-202023-10-2020 07:5723-10-2020 08:00
WP2WP2.01Waiting Estimate23-10-202023-10-2020 07:5623-10-2020 08:00
WP2WP2.12Waiting Estimate23-10-202023-10-2020 07:2823-10-2020 08:00
WP2WP2.13Waiting Estimate23-10-202023-10-2020 07:2723-10-2020 08:00
WP2WP2.14Waiting Estimate23-10-202023-10-2020 07:2723-10-2020 08:00
1 ACCEPTED SOLUTION
BA_Pete
Super User
Super User

@Anonymous ,

 

In Power Query, go to New Source>Blank Query then in Advanced Editor paste my code over the default code. You can then follow the steps I took to complete this.

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WCg8wUtIBkXqGYEZiZklmXrqCa3FJZm5iSSpQyMhY19BA18jAyACFo2BgYWWAVShWB8VYQ9oYa0CiseZWppaEjTWwpI2xFrQx1px0Yy2IMNaMNsaa0sZYE9KNNSfCWGPaGEtqLiPSWFJzGdBYMyJyGemuNSIiygxJD1sjIgLBkPSUgMPYWAA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [stack = _t, position = _t, #"type" = _t, date = _t, time_stamp = _t, most_recent_time_Stamp = _t]),
    chgSourceTypes = Table.TransformColumnTypes(Source,{{"stack", type text}, {"position", type text}, {"type", type text}, {"date", type date}, {"time_stamp", type datetime}, {"most_recent_time_Stamp", type datetime}}),
    groupWithData = Table.Group(chgSourceTypes, {"stack", "type", "date"}, {{"data", each _, type table [stack=nullable text, position=nullable text, type=nullable text, date=nullable date, time_stamp=nullable datetime, most_recent_time_Stamp=nullable datetime]}, {"calcMostRecent", each List.Max([time_stamp]), type nullable datetime}}),
    expandDataCol = Table.ExpandTableColumn(groupWithData, "data", {"position", "time_stamp", "most_recent_time_Stamp"}, {"position", "time_stamp", "most_recent_time_Stamp"})
in
    expandDataCol

 

This will need to be tested on a more diverse dataset as the example data provided only seemed to include one relevant grouping, but it should work fine.

 

Let me know if you have any trouble applying this solution to your actual data.

 

Pete



Now accepting Kudos! If my post helped you, why not give it a thumbs-up?

Proud to be a Datanaut!




View solution in original post

4 REPLIES 4
BA_Pete
Super User
Super User

@Anonymous ,

 

In Power Query, go to New Source>Blank Query then in Advanced Editor paste my code over the default code. You can then follow the steps I took to complete this.

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WCg8wUtIBkXqGYEZiZklmXrqCa3FJZm5iSSpQyMhY19BA18jAyACFo2BgYWWAVShWB8VYQ9oYa0CiseZWppaEjTWwpI2xFrQx1px0Yy2IMNaMNsaa0sZYE9KNNSfCWGPaGEtqLiPSWFJzGdBYMyJyGemuNSIiygxJD1sjIgLBkPSUgMPYWAA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [stack = _t, position = _t, #"type" = _t, date = _t, time_stamp = _t, most_recent_time_Stamp = _t]),
    chgSourceTypes = Table.TransformColumnTypes(Source,{{"stack", type text}, {"position", type text}, {"type", type text}, {"date", type date}, {"time_stamp", type datetime}, {"most_recent_time_Stamp", type datetime}}),
    groupWithData = Table.Group(chgSourceTypes, {"stack", "type", "date"}, {{"data", each _, type table [stack=nullable text, position=nullable text, type=nullable text, date=nullable date, time_stamp=nullable datetime, most_recent_time_Stamp=nullable datetime]}, {"calcMostRecent", each List.Max([time_stamp]), type nullable datetime}}),
    expandDataCol = Table.ExpandTableColumn(groupWithData, "data", {"position", "time_stamp", "most_recent_time_Stamp"}, {"position", "time_stamp", "most_recent_time_Stamp"})
in
    expandDataCol

 

This will need to be tested on a more diverse dataset as the example data provided only seemed to include one relevant grouping, but it should work fine.

 

Let me know if you have any trouble applying this solution to your actual data.

 

Pete



Now accepting Kudos! If my post helped you, why not give it a thumbs-up?

Proud to be a Datanaut!




Anonymous
Not applicable

@BA_Pete ,

 

Thanks, is working fine!

 

John

BA_Pete
Super User
Super User

Hi @Anonymous ,

 

You said you need a calculation to do this. Do you specifically need this done in DAX, or would a Power Query/M solution suit?

 

Pete



Now accepting Kudos! If my post helped you, why not give it a thumbs-up?

Proud to be a Datanaut!




Anonymous
Not applicable

HI @BA_Pete ,

Well, I am not an expert, but lets give it a try in Power Query/ M 😀

Thanks upfront for your help!

John

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!

December 2024

A Year in Review - December 2024

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