Is UV the FUTURE of Python PACKAGING? 🐍📦

Поделиться
HTML-код
  • Опубликовано: 12 янв 2025

Комментарии • 75

  • @The_Hynek
    @The_Hynek  3 месяца назад

    Six months later, I've recorded an answer to this video! Check it out: ruclips.net/video/8UuW8o4bHbw/видео.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!

  • @MiguelRodriguez-fm4zb
    @MiguelRodriguez-fm4zb 10 месяцев назад +2

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

  • @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

  • @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.

  • @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.

  • @Eriddoch
    @Eriddoch 4 месяца назад +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  4 месяца назад

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

  • @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 :)

  • @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 10 месяцев назад

      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 🤣

  • @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!

  • @AndreasJung
    @AndreasJung 10 месяцев назад +4

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

  • @pr_tech_team
    @pr_tech_team 9 месяцев назад +3

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

    • @The_Hynek
      @The_Hynek  9 месяцев назад

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

    • @pr_tech_team
      @pr_tech_team 9 месяцев назад

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

  • @yafz
    @yafz 10 месяцев назад +3

    Very nice, very well-informed overview!

  • @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.

  • @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. 😫

  • @imaurer
    @imaurer 10 месяцев назад +1

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

  • @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. 😂

  • @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)

  • @blaiseutube
    @blaiseutube 10 месяцев назад +2

    Yes, the Beaver logo is awesome.

  • @Taaz2
    @Taaz2 5 месяцев назад +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  5 месяцев назад +1

      You and everybody else my friend. 😅

  • @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

  • @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

  • @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 RUclips. Or that his tight, concise style didn't have an influence on me. :)

  • @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).

  • @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.

  • @InDaHoops
    @InDaHoops 10 месяцев назад

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

  • @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 😅

  • @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/ 🤓

  • @-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.

  • @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. :)

  • @aliakbarsaleh382
    @aliakbarsaleh382 10 месяцев назад +1

    Enjoyed 🎉👍

  • @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.

  • @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  8 месяцев назад

      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 8 месяцев назад

      @@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.

  • @knolljo
    @knolljo 9 месяцев назад +1

    based takes

  • @pouet4608
    @pouet4608 6 месяцев назад

    Just use ant.

  • @awakenerd1101
    @awakenerd1101 4 месяца назад

    I have no idea. I prefer pip.