Simple Python [executable] version management, that is.

  • Andy@programming.dev
    link
    fedilink
    arrow-up
    5
    ·
    2 years ago

    I highly recommend rtx over pyenv/asdf. For one thing, you’ll still be able to which python and get a useful response, as it works by altering your PATH rather than relinking shims.

    • brettvitaz@programming.dev
      link
      fedilink
      arrow-up
      2
      ·
      2 years ago

      I wouldn’t argue that a useful response from which isn’t a good thing, but how often do you need to use it with Python? I’ve been using pyenv with pipenv for years and almost never need to do this.

      • Andy@programming.dev
        link
        fedilink
        arrow-up
        1
        ·
        2 years ago

        How often? Sometimes 🤷.

        There are other benefits to the tool that may be more meaningful for your usage, but of course I wouldn’t claim there’s anything wrong with using the tools you like.

        I think when I used pyenv it was the single slowest part of my shell initialization.

  • n-gons@vlemmy.net
    link
    fedilink
    arrow-up
    4
    ·
    edit-2
    2 years ago

    I use it everyday. I feel it’s my secret sauce in python dev… pyenv-virtualenv is pretty useful with it also

  • jeebus@programming.dev
    link
    fedilink
    English
    arrow-up
    3
    ·
    edit-2
    2 years ago

    When bringing people online from other languages, I first get them to find out what python there is in their environment and go with that if it’s recent enough. Then I tell them about pyenv and it’s plugins after a bit. Whenever I go straight into installing pyenv, it feels like I’m throwing some one in the deep ocean.

    • muppetjones@lemm.ee
      link
      fedilink
      English
      arrow-up
      2
      ·
      2 years ago

      I’ve seen too many issues caused by relying on the system python. For starters, it’s much more difficult to fix if you screw something up.

      I tell everyone to use pyenv – but only to install specific versions of python. I then create a primary venv for a couple of versions, and that’s what I use as my “system” version. Each project creates a separate venv based on the pyenv versions. I use autoenv to activate and deactivate as needed.

      It’s a little more setup, but it avoids so much magic, and it’s extremely robust.

  • CodeBlooded@programming.dev
    link
    fedilink
    arrow-up
    3
    ·
    2 years ago

    I found pyenv to be buggy at times, not properly setting the default (global) python version. I ultimately uninstalled pyenv and also uninstalled any additional Python installs outside of the system default.

    Now, I do 100% of my Python work inside of Docker containers. This has solved any issues I’ve ever had with Python environments and PYTHONPATH . It’s also made me a stronger developer when it comes to using Docker.

    I don’t see myself ever going back. A Docker container is the perfect Python environment.

  • redcalcium@c.calciumlabs.com
    link
    fedilink
    arrow-up
    2
    ·
    2 years ago

    Another useful Python version manager is asdf with python plugin. The most helpful feature of asdf is ability to specify what Python version to use in certain directory by simply placing a .tool-versions file (contains the version number to use) in that directory. This makes working with multiple projects that requires different version of Python very seamless.

  • Jim@programming.dev
    link
    fedilink
    English
    arrow-up
    2
    ·
    2 years ago

    I’ve used pyenv for years and it’s an awesome tool. Keeps python binaries separate and it has a virtualenv plugin. I’ve gotten others to use it as well.

    It works great for library owners who need to run tox/nox on multiple versions of python in test suites. Love it.