Is UV the FUTURE of Python PACKAGING? 🐍📦

Поділитися
Вставка
  • Опубліковано 3 січ 2025

КОМЕНТАРІ • 75

  • @The_Hynek
    @The_Hynek  3 місяці тому

    Six months later, I've recorded an answer to this video! Check it out: ua-cam.com/video/8UuW8o4bHbw/v-deo.html

  • @StargirlFlowers
    @StargirlFlowers 10 місяців тому +7

    Wonderful video, Hynek! You did a great job of capturing how tumultuous Python packaging has been over the years. It was really exciting to see the speed up UV granted Nox when reviewing the PR. :)

    • @The_Hynek
      @The_Hynek  10 місяців тому

      Thank you Thea! 💜💜💜

  • @tamirbahar
    @tamirbahar 10 місяців тому +13

    Can't beat informed takes on Python packaging!

  • @pythonlibrarian224
    @pythonlibrarian224 10 місяців тому +8

    As a build master in my day job, this is the best content ever

  • @WilliamJamir
    @WilliamJamir 10 місяців тому +4

    This breakdown of Python packaging is terrific!
    Thanks Hynek sharing your insights and perspectives!

  • @mfeickert07
    @mfeickert07 10 місяців тому +2

    Such a great video, Hynek! I am adding this to my "Understanding Python virtual environments" Gist that I share with my students. Thanks and best wishes on the channel!

  • @miketheman
    @miketheman 10 місяців тому +8

    Not enough mic punching 😂. Excellent video, love the deep dive on resolving. Do you think that Python tools not written in Python will attract a similar level of contributor support?

    • @The_Hynek
      @The_Hynek  10 місяців тому +4

      yes, not punching, BUT: check out how it’s wobbling around especially by the end! (background: the mic is on a boom, but the boom is connected to my table so when i touch the table…)
      and no I don’t think they will, and I do think it’s a problem, but packaging has currently bigger problems so I’m still bullish on it in general!

  • @Eriddoch
    @Eriddoch 3 місяці тому +1

    Dude way cool! Subbed (which is rare for me)
    I've been staff ML Platform engineer. I was caught completely off guard by how mature your take is.
    I love that you could speak to an announcement back in the day when setuptools maintenance was handed over to the community.
    Also had no idea about the pip conf file or that PDM attempts to do x-platform lockfiles.

    • @The_Hynek
      @The_Hynek  3 місяці тому

      Thank you so much! Secret teaser: I'm writing the successor to this video right now!

  • @rednafi
    @rednafi 10 місяців тому +1

    Fantastic overview. I love these nuggets of knowledge. Packaging is such a hard problem that it's incredibly difficult for a group of volunteers to solve without any VC backing. I'm glad Astral is addressing this issue.

  • @wodny85
    @wodny85 10 місяців тому +5

    Well-balanced and funny as always. (I would omit the morphing transitions, though)

    • @The_Hynek
      @The_Hynek  10 місяців тому +1

      Thanks!
      Interesting… do you mean the fill-ins to soften cuts or the ~3 real transitions (before/after the paper and at the very end IIRC)?

    • @wodny85
      @wodny85 10 місяців тому +1

      @@The_Hynek The former. My brain reports: "aha, it is some trickery, the man just glitched into another dimension for a fraction of a second, we shall follow him to the comments section".

    • @The_Hynek
      @The_Hynek  10 місяців тому +2

      Right, in fact I think FCP added a few that I didn’t want added (between real cuts) that added some uncanny valley. I’ll try to catch those better next time!

    • @RandomAcronyms
      @RandomAcronyms 9 місяців тому

      Glad I wasn't the only one that noticed. 😂

    • @jjn2469
      @jjn2469 4 місяці тому

      i thought i was watching AI for a second when i saw it 🤣

  • @ashemedai
    @ashemedai 8 місяців тому +2

    Small addition to the video around 6:55, the ~/.pip/pip.conf location is the legacy location. It nowadays follows XDG and prefers ~/.config/pip/pip.conf.

  • @sethmlarson
    @sethmlarson 10 місяців тому +2

    This was a great video Hynek! The "consistent goal-post moving" take hits home, Python is building on a lot of history :)

  • @asfaltboy
    @asfaltboy 10 місяців тому +3

    Those little octopi behind you look like the Octopus energy mascots!

    • @The_Hynek
      @The_Hynek  10 місяців тому +1

      Finally someone noticed!
      I got them from PyCon UK 2023 where their tech arm had a recruiting booth.

  • @xDarknessCrusherx
    @xDarknessCrusherx 3 місяці тому +1

    Amazing video, Hynek! Just learn more about history of python packaging, than in a few years working with python as a primary tool

  • @MiguelRodriguez-fm4zb
    @MiguelRodriguez-fm4zb 10 місяців тому +2

    Great video! Appreciate you sharing your hard-earned opinions with all of us.

  • @02TLE
    @02TLE 10 місяців тому +2

    Thanks. Really great video. I'm wondering. Your final take away on you being sceptical about Astral being able to deliver on "Cargo for Python", is that fundamentally rooted in the cross platform lock files problem or something more fundamental?

    • @The_Hynek
      @The_Hynek  10 місяців тому +2

      To be clear: I'm not skeptical it's possible, I'm just skeptical it's gonna happen anytime soon. As I've outlined, it's a much more difficult problem to implement a Cargo for Python that to implement a Cargo for Rust. But it's currently our only hope.

    • @02TLE
      @02TLE 10 місяців тому

      @@The_Hynek I understand, thanks

  • @sandipb
    @sandipb 10 місяців тому +3

    Great content, as always. About your format - it is definitely better to have more shorter videos rather than fewer longer videos. A 10-20 minutes video is easy to pick up impulsively over a coffee break even in the middle of the week, instead of all those 30+ minutes videos languishing in my reading list waiting for me to get a large enough block of time to view them.

    • @The_Hynek
      @The_Hynek  10 місяців тому +1

      I SWEAR I'm trying to make JUST ONE video under 10 minutes. I'M TRYING. 😫

  • @blaiseutube
    @blaiseutube 10 місяців тому +2

    Yes, the Beaver logo is awesome.

  • @pr_tech_team
    @pr_tech_team 8 місяців тому +3

    Good video. I was undecided on uv vs pdm. You shed some nice light on the differences

    • @The_Hynek
      @The_Hynek  8 місяців тому

      Yeah currently the answer for me is both: hynek.me/articles/python-virtualenv-redux/

    • @pr_tech_team
      @pr_tech_team 8 місяців тому

      Nice. I like the direnv approach for activating venv
      I used to use pyenv for managing version, now I’ve switched to mise

  • @AndreasJung
    @AndreasJung 10 місяців тому +4

    Thank you for explaining the Python packaging world. I am fully with you.

  • @yeraydiazdiaz
    @yeraydiazdiaz 10 місяців тому +1

    Great overview of Python packaging and why it's a hard problem. That mic looked a lot happier this time around. 8pt font - 'and one week to rip off' LOL

    • @The_Hynek
      @The_Hynek  10 місяців тому

      It was so happy it wobbled the whole time. 😅 (see my reply to Mike why)

  • @yafz
    @yafz 10 місяців тому +3

    Very nice, very well-informed overview!

  • @dafoster
    @dafoster 10 місяців тому +1

    Great content Hynek! I learned a fair bit about the low-level packaging tools in the Python ecosystem. I've been using Poetry for long enough that I almost forgot that virtualenvwrapper and friends still exist.
    RE ideas to improve the video, captions would be a big plus. It can be difficult to understand technical terms in an unfamilar accent, and automatic captioning doesn't help when such terms are involved. I realize it's probably a fair bit of work to add manual captions, but maybe there are some tools to semi-automate the process these days, especially with the rise of GenAI.

    • @The_Hynek
      @The_Hynek  10 місяців тому

      thanks!
      yeah I would LOVE to provide captions (I use them myself a lot) but it's so much work :-/ I'm trying to put important terms on the screen in writing as a compromise. Not sure GenAI can work with my Czech-German accent. 😂

  • @imaurer
    @imaurer 10 місяців тому +1

    Keep it up Hynek! Thanks for tampering my uv excitement just a tad. lol

  • @traal
    @traal 10 місяців тому +1

    Nice Cortex T-shirt! 😀 Fellow Cortexan here from Sweden.

    • @The_Hynek
      @The_Hynek  10 місяців тому

      Yesss! 💪
      I would also be lying if I said that listening to CGP Grey for years didn't get me into UA-cam. Or that his tight, concise style didn't have an influence on me. :)

  • @Taaz2
    @Taaz2 4 місяці тому +1

    I can't wait for "native" lockfiles - managing requirements.txt myself always felt annoying at best. Hope it also makes containerization feel like less of a chore.

    • @The_Hynek
      @The_Hynek  4 місяці тому +1

      You and everybody else my friend. 😅

  • @ej3281
    @ej3281 10 місяців тому

    Sounds like the remaining "big unsolved problems" are: cross-platform dependencies are hard to spec out and a pain to compile (upcoming PEP may help), the speed of packaging code in hot loops should be faster, the fact that solving dependencies is NP complete sucks, the reliance of scientific packages on programs in other languages creates additional finnicky dependencies, compile dependencies require lots of troubleshooting and yaml soup, support for virtual environments that doesn't overwhelm new users, and creating a simple interface that is easy to use. Does that sound right?

    • @The_Hynek
      @The_Hynek  10 місяців тому

      Depends what you mean big unsolved for what. The PEP will define a format, but not make it easier to resolve. All resolvers in Python currently trip over certain technically solvable situations. The locking format is HOPEFULLY just a formality and once uv's resolver improves, I don't think implementing the lock file will be a big deal. So yeah, the only big unresolved problem is the NP-complete dependency resolution that's made more difficult by Python's diverse landscape - combined with Python's single namespace (e.g. in Rust, resolution is simpler since you can add a dependency several times - they don't create a constraint that complicates the solution).

  • @iacopospalletti7440
    @iacopospalletti7440 10 місяців тому +1

    Great video both on the content side and on the production one. While I usually get very bored with python packaging drama (as you pointed out it's now mostly ill informed reheated old soup) I'm very curious about what uv can deliver

    • @The_Hynek
      @The_Hynek  10 місяців тому

      Thank you, me too! 😅

  • @dunderstr
    @dunderstr 10 місяців тому +1

    Wonderful video, Thank you Hynek

  • @RobertFletcherOBE
    @RobertFletcherOBE 10 місяців тому +1

    im still sad were all moving to toml. a format abandoned by its own creator on account of what a mistake they felt it was.

  • @EngineerNick
    @EngineerNick 8 місяців тому

    No one seems to talk about hatch :( Oh well, another one then.

    • @The_Hynek
      @The_Hynek  8 місяців тому

      Hatch added support for uv: hatch.pypa.io/1.10/blog/2024/05/02/hatch-v1100/ 🤓

  • @AlexWillmer
    @AlexWillmer 10 місяців тому +1

    > Open Source maintainers spend a lot of time waiting for CI
    Literally watching this while I wait for Azure DevOps jobs 😄

    • @The_Hynek
      @The_Hynek  10 місяців тому

      the pain is real 😅

  • @-iIIiiiiiIiiiiIIIiiIi-
    @-iIIiiiiiIiiiiIIIiiIi- 3 місяці тому

    uv does not have a built-in command to list all virtual environments. Unlike Conda that provide commands like 'conda env list'.

    • @The_Hynek
      @The_Hynek  3 місяці тому

      It's kinda hard to list all virtual environments when they aren't stored in a central place. It's just a different philosophy that is preferred by most people (myself NOT included) - for better and for worse.

  • @InDaHoops
    @InDaHoops 10 місяців тому

    Whenever a tool claims to solve all our problems it solves them but introduces worse ones

  • @matmair1915
    @matmair1915 10 місяців тому +5

    Love the small rip off comment

    • @The_Hynek
      @The_Hynek  10 місяців тому +3

      🤐

    • @matmair1915
      @matmair1915 10 місяців тому +1

      @@The_Hynek won't bug you about that ever again - appreciate you, regardless of the medium!

    • @The_Hynek
      @The_Hynek  10 місяців тому +1

      @@matmair1915 all good, I’m surprised/amused ppl noticed immediately. :)

  • @blaiseutube
    @blaiseutube 10 місяців тому

    so.... pipx install uv ?

    • @The_Hynek
      @The_Hynek  10 місяців тому

      For example! github.com/astral-sh/uv?tab=readme-ov-file#getting-started I use pipx myself too.

  • @aliakbarsaleh382
    @aliakbarsaleh382 10 місяців тому +1

    Enjoyed 🎉👍

  • @pouet4608
    @pouet4608 5 місяців тому

    Just use ant.

  • @knolljo
    @knolljo 9 місяців тому +1

    based takes

  • @theevilcottonball
    @theevilcottonball 8 місяців тому

    The probem with python packaging is, that there are too many tools and you do not know which one to use, or whether you need it all. Adding more packaging tools will not solve this.

    • @The_Hynek
      @The_Hynek  7 місяців тому

      That wouldn’t be a problem if all the tools did everything necessary which is emphatically not the case. Whether one of the existing tools will grow to a 100% solution or whether we will need a new one is kinda unrelated. The actual problem is the vast problem space, as I’ve tried to illustrate, which is the reason why we have many 90% solutions with varying missing 10%.

    • @theevilcottonball
      @theevilcottonball 7 місяців тому

      @@The_Hynek Yeah maybe I should rephrase this: *My* problem with python packaging is that there are too many tools and *I* do not know whicht to use. Should I use a solution that appears easy to use (like poetry) or use the low level tools venv, pip, setuptools. As a non-proffesional developer I solve this stuff by not packing stuff at all, sometimes I write my stuff in C so I can just distribute an EXE easily and not have to tell Python users to install the dependencies manually.

  • @awakenerd1101
    @awakenerd1101 3 місяці тому

    I have no idea. I prefer pip.