• rtxn@lemmy.world
      link
      fedilink
      arrow-up
      21
      ·
      1 month ago

      timedelta marks time in days, seconds, and microseconds. It doesn’t take leap years into account because the concept of years is irrelevant to timedelta. If you need to account for leap years, you need a different API.

    • wols@lemmy.zip
      link
      fedilink
      arrow-up
      12
      ·
      1 month ago

      The comparison is somewhat awkward, because the rails example presumably produces a date, while the python one is referring to an interval of time.
      Just from the meme it’s not obvious which was the actual intended use, so labeling either as inaccurate requires us to make assumptions.

      Personally, the concept of “10 years ago” is a bit nebulous to me. If today is February 29th, is ten years ago March 1st? Doesn’t seem right. Or particularly useful.

    • Eager Eagle@lemmy.world
      link
      fedilink
      English
      arrow-up
      9
      ·
      edit-2
      1 month ago

      Because what’s accurate here depends on the context, and the Python example doesn’t hide that from the programmer.

      The same dilemma goes for month calculations: does “3 months ago” mean 90 days ago, 91.3 days ago, this many days into the target month, or this many days from the target month’s end (e.g. to account for 28, 29, 30, and 31-day months)?

  • _stranger_@lemmy.world
    link
    fedilink
    arrow-up
    32
    arrow-down
    1
    ·
    edit-2
    1 month ago

    Ok, everyone who’s ever had to use datetime hates it, but not because it’s insufficient, but because international date/time is such a nightmare that the library must be complicated enough to support all the edge cases I’m convinced that library has a function for traveling trough time.

    For years I’ve wrapped datetime with custom functions that do exactly and only what I want to mitigate its all-plumbing-zero-porcelain approach to the problem.

    • ripcord@lemmy.world
      link
      fedilink
      arrow-up
      8
      ·
      edit-2
      1 month ago

      Complicated or not, the interfaces suck. And dont have to. And that’s the problem.

      • Alaknár@sopuli.xyz
        link
        fedilink
        English
        arrow-up
        1
        ·
        1 month ago

        This is exactly why I love PowerShell.

        Need the [DateTime] object from 10 years ago? No biggie, just chuck (Get-Date).AddYears(-10) down your console.

        Need it in a specific timezone? That one’s trickier, but since PowerShell can do .Net, run this:

        $TargetDateTime = (Get-Date).AddYears(-10)
        $TargetTimeZone = "India Standard Time"
        $tz = [TimeZoneInfo]::FindSystemTimeZoneById($TargetTimeZone)
        $utcOffset = $tz.GetUtcOffset($TargetDateTime)
        [DateTimeOffset]::new($TargetDateTime.Ticks, $utcOffset)
        

        And you get a DateTimeOffset object, which is this beauty:

        DateTime           : 25/08/2015 23:15:14
        UtcDateTime        : 25/08/2015 17:45:14
        LocalDateTime      : 25/08/2015 19:45:14
        Date               : 25/08/2015 00:00:00
        Day                : 25
        DayOfWeek          : Tuesday
        DayOfYear          : 237
        Hour               : 23
        Millisecond        : 421
        Microsecond        : 428
        Nanosecond         : 600
        Minute             : 15
        Month              : 8
        Offset             : 05:30:00
        TotalOffsetMinutes : 330
        Second             : 14
        Ticks              : 635761413144214286
        UtcTicks           : 635761215144214286
        TimeOfDay          : 23:15:14.4214286
        Year               : 2015
        

        DateTime is the time in your target timezone, UtcDateTime is, well, the UTC time, and LocalDateTime is the time on host you ran the commands on.

  • bleistift2@sopuli.xyz
    link
    fedilink
    English
    arrow-up
    17
    ·
    1 month ago

    Fuck that. I once used a constraint solver in python where you could += a constraint to a problem. This is completely un-discoverable. In any sane language you can use IntelliSense to find that you can problem.add(constraint) and be done with it without ever touching a manual. Overloaded operators are cool, but a menace.

    And while I’m ranting: Angular’s new addRouting(), withThingA(), withThingB() is complete horseshit, too. The old way of doing addRouter({ and letting the IDE tell you what you could to with the router was so much clearer!

    • _stranger_@lemmy.world
      link
      fedilink
      arrow-up
      3
      ·
      edit-2
      1 month ago

      I’ll take overloaded operators over overloaded functions any day of the week, and I also hate overloaded operators.

      Python’s optional typing has come a very long way in the past few years, you might be able to mitigate this with some creative application of typing.

      Edit: I read your post closer, I’m not sure typing would help with the overloaded operator issue and now I have something fun to try out later 😁

    • marcos@lemmy.world
      link
      fedilink
      arrow-up
      1
      arrow-down
      1
      ·
      1 month ago

      Any good inline help would run dir into your variable and discover it overloads that operator. It’s a fault of your tools.

  • friend_of_satan@lemmy.world
    link
    fedilink
    English
    arrow-up
    16
    ·
    edit-2
    1 month ago

    This implies that integers in ROR are complex objects with properties that would be unhelpful in the majority of scenarios. Is that right?

    • myotheraccount@lemmy.world
      link
      fedilink
      arrow-up
      15
      ·
      1 month ago

      Integers are just integers in ruby, with no structure backing them. They behave like objects, but only in some respects. You can call methods on them, but you can’t extend individual numbers with properties for example (which would require them to have structure).

  • Victor@lemmy.world
    link
    fedilink
    arrow-up
    9
    arrow-down
    1
    ·
    edit-2
    1 month ago

    I’m gonna be honest, I never was drawn to python. I’ve been a professional developer for about a decade, and I’ve written all of one (1) python programs that I can remember (for my own personal use, mind).

    • addie@feddit.uk
      link
      fedilink
      arrow-up
      12
      ·
      1 month ago

      What you can achieve in a couple of pages of Python can be pretty spectacular. It’s also mostly very easy-to-read, with the possible exception of class inheritance, which is confusing mess.

      If you need to write more than a couple of pages, then its lack of types becomes a hindrance to me - doing refactors when functions can take basically any arguments is quite painful, for instance. Not requiring any particular structure is great, up until you start to struggle with lack of structure.

      Ideal programming language for when you’re wanting to do something that would be a bit too unwieldy for a shell script. It also makes network requests and json parsing very straightforward, so it’s great for interacting with REST APIs and writing simple microservices. Fast to write and runs quite quickly, so a good choice for Advent Of Code-like tasks. Would probably choose a different language for larger projects or when working in a team, though.