• ERROR: Earth.exe has crashed@lemmy.dbzer0.com
    link
    fedilink
    English
    arrow-up
    40
    arrow-down
    2
    ·
    13 days ago
    If
    "am/pm indicator" = "pm"
    AND
    "hour" =/= "12"
    ADD "12" to "hour"
    
    Else
    Ignore the am/pm indicator, time is correct in 24 hour format.
    

    Disclaimer: I am not a programmer, I have no idea if my “code” is written in the correct format.

    • Zagorath@aussie.zone
      link
      fedilink
      English
      arrow-up
      28
      ·
      13 days ago

      As far as pseudocode goes, this is pretty damn good. The main thing I’d change is that things in “quotes” generally represent strings, i.e. literal text. Variable names usually don’t have quotes around them. That’s a universal enough trait of real programming languages that it would almost never not transfer to pseudocode. Also, numbers intended to be read as numbers don’t typically have quotes.

      How I would change this accordingly
      If
      am_pm_indicator = "pm"
      AND
      hour =/= 12
      ADD 12 to hour
      
      Else
      Ignore the am/pm indicator, time is correct in 24 hour format. # Leaving this as-is because it's more like a comment than code anyway
      
        • AliasVortex@lemmy.world
          link
          fedilink
          English
          arrow-up
          23
          ·
          edit-2
          13 days ago

          We call that pseudocode and it looks fine to me. No computer will run it natively (AI meat grinders aside), but most devs will be able to pick up on the logic and convert it to actual code.

          Disclaimer: am a programmer.

          Edit: as an aside, manually dealing with time is its own form of madness and is usually best left to libraries (ie other people’s code) whenever possible.

            • bamboo@lemmy.blahaj.zone
              link
              fedilink
              English
              arrow-up
              5
              ·
              13 days ago

              Wow I’ve seen some really weird backwards compatibility issues, but this takes the cake. I would have imagined that in the move to XLSX they could have addressed this and sorted it out when saving, but nope, I guess having all days off by one and maintaining a support page explaining Lotus123 backwards compatibility for forever is earlier?

        • b000rg@midwest.social
          link
          fedilink
          English
          arrow-up
          7
          ·
          13 days ago

          This is honestly exactly what programming is: breaking down big problems into step by step simple problems. If you’ve never considered taking up programming before, I’d suggest you try it sometime and see where it takes you. It’s not hard to learn, it just takes time.

        • bandwidthcrisis@lemmy.world
          link
          fedilink
          arrow-up
          3
          ·
          13 days ago

          COBOL is an old language Internet to make programs look a bit like English descriptions of what was needed.

          I don’t really know it, but your code reminded me of the idea of it.

          Don’t worry if your code is incorrect, just make random changes until you hit on something that no longer results in errors :)

    • LwL@lemmy.world
      link
      fedilink
      arrow-up
      6
      ·
      12 days ago

      If only this was true, but for some reason midnight is 12 am. And noon is 12 pm (I’m aware that the reason is that 12:00:00.00001 is in the second half of the day. I just think it should be called 0 pm).

      • Midnight is 00:00 is 12am. They accounted for 12pm, but need to subtract 12 if it’s 12am.

        So, you’d do away with 12 entirely and make AM/PM 0-based: 00:00am - 11:59am, and then 00:00pm - 11:59pm? Makes sense if you’re a programmer, but 0 is a fairly recent invention, and most daily measuring concepts are fundamentally 1-based. Heck, we couldn’t even get all programming languages to agree on 0-based array indexing (looking at you, MATLAB, and you, bash).

    • renzev@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      19
      arrow-down
      1
      ·
      13 days ago

      yeah, adding twelve to a single-digit number really does make my brain freeze like that. Something something can’t do math under pressure.

      • JustAnotherKay@lemmy.world
        link
        fedilink
        arrow-up
        4
        ·
        13 days ago

        This might help you: you’re not adding 12 to a single-digit number. Just do 2 + x then throw a 1 in front, or add 10. Whichever is easier to conceptualize. (Where x is the single-digit number, in case that needed clarifying)

  • RememberTheApollo_@lemmy.world
    link
    fedilink
    arrow-up
    14
    ·
    12 days ago

    After a while there is no conversion necessary. 5 pm is 5 pm is 17:00. They are the same. UTC to local however can get fucked. Time zone variables, daylight standard/savings variables, no thanks.

    • Yeah, I never found adding 12 to or from a number to be particularly challenging. Still, I do wish AM/PM would go away, not to mention DST. Can’t escape UTC and time zones, though, not reasonably, anyway. If for no other reason than doing the conversion makes you aware of how inconvenient your suggested meeting time is for the other party.

        • Crashumbc@lemmy.world
          link
          fedilink
          English
          arrow-up
          5
          ·
          13 days ago

          Jesus does no one know 24hr time? No it is not it is the first hour…

          12:10 am = 00:10 in 24hr time…

          • Omnipitaph@reddthat.com
            link
            fedilink
            arrow-up
            3
            arrow-down
            2
            ·
            edit-2
            12 days ago

            You’re still not correct. Here

            You are correct that 12:10 is 00:10, but that’s not what was said. I said 12am is the 24th hour.

            Plop in 24:00 into military, guess what you get? 12am my guy.

            I’ll explain why this is the case. 12am is marking the 12th hour of the evening, 12:01+ is counting into the first hour of the next morning. Same with 24th hour, 24:00 is the end of the 24th hour. There is no 24:01, it rolls around to 00:01 marking the first minute of the next day. 24:00 still exist though, it marks the massing of the last minute of the last hour of the day.

            • 404
              link
              fedilink
              English
              arrow-up
              1
              ·
              edit-2
              11 days ago

              What? The US military uses 24 for just one minute? Seems so unnecessary. Why would they do that?

              World     US military
              
              HH:MM:SS  HH:MM:SS
              23:59:59  23:59:59
              00:00:00  24:00:00
              00:00:01  24:00:01
              00:00:02  24:00:02
              ...         ...
              00:00:59  24:00:59
              00:01:00  00:01:00
              00:01:01  00:01:01
              

              Really? Do they order custom clocks for this etc? Do they have custom settings on their computers to add that extra minute?

              Edit: It says in the time chart on the site you linked that 00:00 = 12 am. What are you on about?