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
TrekJournal
Frequent Visitor

Measure subtract if cardnumber does not check out

Hi,

I need some help with a measure:

VAR __Datum = MAX('Garage UT'[DateTimeG])
VAR __InTotaal =
    CALCULATE(
        COUNT('Garage UT'[Card Number]),
        'Garage UT'[In/UitG] = 1,
        'Garage UT'[DateTimeG] <= __Datum,
        ALLSELECTED('Garage UT')
    )
VAR __UitTotaal =
    CALCULATE(
        COUNT('Garage UT'[Card Number]),
        'Garage UT'[In/UitG] = 2,
        'Garage UT'[DateTimeG] <= __Datum,
        ALLSELECTED('Garage UT')
    )
RETURN
    IF(COUNT('Garage UT'[Card Number]) <> BLANK(),
    __InTotaal - __UitTotaal
    )

It is working perfectly, but it can happen that a cardnumber is inside, but forgets to check out.

I want to make it that when a cardnumber is inside (__InTotaal) and does not check out (__UitTotaal) within 2 days, it should subtract the total count.

 

Does anyone have a great idea how to get this to work?

Regards,
Bianca

1 ACCEPTED SOLUTION

I would separate the Ins and Outs, and then for each In find a corresponding out within 48 hours (or flag it if that is absent)

 

lbendlin_0-1717701666071.png

 

let
  Source = Table.FromRows(
    Json.Document(
      Binary.Decompress(
        Binary.FromText(
          "ZY5LCsQwDEOvMnjdguVP0uoqIfe/Rk1nWgYC0u7xpDEE5pGyCaqx525q8QFoFZO5DYls/ViIpAdx3sTjsGq+xEEo/esow4mfwx9CO9Wpuqz0v5XoBBZHex2NGbT6MS8=",
          BinaryEncoding.Base64
        ),
        Compression.Deflate
      )
    ),
    let
      _t = ((type nullable text) meta [Serialized.Text = true])
    in
      type table [#"Card Number" = _t, #"In/UitG" = _t, DateTimeG = _t]
  ),
  #"Changed Type" = Table.TransformColumnTypes(Source, {{"DateTimeG", type datetime}}, "nl"),
  #"Added Custom" = Table.AddColumn(
    #"Changed Type",
    "Matched UitG",
    (k) =>
      try
        Table.SelectRows(
          #"Changed Type",
          each [Card Number]
            = k[Card Number] and [#"In/UitG"]
            = "2" and [DateTimeG]
            > k[DateTimeG] and [DateTimeG]
            < k[DateTimeG]
            + #duration(2, 0, 0, 0)
        ){0}[DateTimeG]
      otherwise
        null,
    type datetime
  )
in
  #"Added Custom"

How to use this code: Create a new Blank Query. Click on "Advanced Editor". Replace the code in the window with the code provided here. Click "Done". Once you examined the code, replace the Source step with your own source.

 

View solution in original post

5 REPLIES 5
lbendlin
Super User
Super User

what should happen when you have two checkins for the same card number but only one checkout?  are card numbers static or are they rotating?

Why 2 days?  is there a reason behind that limit?  Or do you rather want to have a report that pairs all Ins with all Outs and shows the time between? So you can see the patterns better.

Thank you for your reply.

What I'm trying to show is how many card numbers are inside by hour and day.
We want to know how much parkingspaces are occupied at hourly basis on any given day.
But card can come inside one day and leave another day.
We concluded that no card stays more than 48 hours, thats why I need to subtract the count when a card is inside more than 2 days (or 48 hours).

 

My data looks like this:

Card NumberIn/UitGDateTimeG
1234514-5-2024 11:21:22
4567814-5-2024 15:34:19
1234525-5-2024 18:10:32
6789113-5-2024 07:03:00
4567817-5-2024 15:47:11
6789116-5-2024 06:54:29

 

So card number 12345 checked in on the fourth and left on the fifth. the other two didn't check out, but checked in on another day.

Oooh, that's a lot of assumptions.  What if they go on vacation?  Or even a long weekend?  What if they mess with you and use the same card for different cars?

Well that could be the case, but let's assume that an employee will not stay parked in the garage while they are on vacation.
They cannot go back inside, unless the card gets "reset". Unfortunatly the system does not show the card numbers that get reset (else my life would be that much easier ;-)).

Do you have any suggestions in how to make this work?

I would separate the Ins and Outs, and then for each In find a corresponding out within 48 hours (or flag it if that is absent)

 

lbendlin_0-1717701666071.png

 

let
  Source = Table.FromRows(
    Json.Document(
      Binary.Decompress(
        Binary.FromText(
          "ZY5LCsQwDEOvMnjdguVP0uoqIfe/Rk1nWgYC0u7xpDEE5pGyCaqx525q8QFoFZO5DYls/ViIpAdx3sTjsGq+xEEo/esow4mfwx9CO9Wpuqz0v5XoBBZHex2NGbT6MS8=",
          BinaryEncoding.Base64
        ),
        Compression.Deflate
      )
    ),
    let
      _t = ((type nullable text) meta [Serialized.Text = true])
    in
      type table [#"Card Number" = _t, #"In/UitG" = _t, DateTimeG = _t]
  ),
  #"Changed Type" = Table.TransformColumnTypes(Source, {{"DateTimeG", type datetime}}, "nl"),
  #"Added Custom" = Table.AddColumn(
    #"Changed Type",
    "Matched UitG",
    (k) =>
      try
        Table.SelectRows(
          #"Changed Type",
          each [Card Number]
            = k[Card Number] and [#"In/UitG"]
            = "2" and [DateTimeG]
            > k[DateTimeG] and [DateTimeG]
            < k[DateTimeG]
            + #duration(2, 0, 0, 0)
        ){0}[DateTimeG]
      otherwise
        null,
    type datetime
  )
in
  #"Added Custom"

How to use this code: Create a new Blank Query. Click on "Advanced Editor". Replace the code in the window with the code provided here. Click "Done". Once you examined the code, replace the Source step with your own source.

 

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.

Jan NL Carousel

Fabric Community Update - January 2025

Find out what's new and trending in the Fabric community.