V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
yazoox
V2EX  ›  Python

大家有没有比较好的经验,管理两个版本的 Python , 2 & 3?

  •  
  •   yazoox · 16 天前 · 5432 次点击

    发现很多程序的运行环境,都需要 python 支持,而且,版本还不一样。python2 和 python3 都需要。

    楼主一直整得不太好(因为不是经常使用),经常一个程序或者环境跑起来,缺 python 。所以特意来请教一下,大家有没有比较好的 best practice ,管理 python 的版本,2 & 3 ,以及对应的 pip 。

    macOS 和 windows 都分别怎么设置,比较好用&通用?

    谢谢!

    第 1 条附言  ·  16 天前
    补充一下,可能是我没有说清楚。

    我不是要在 python2 的多版本,或者 python2 & python3 之间切换。\
    而是需要多个 python 版本共存,同时生效。

    比如,安装 neovim ,他的设置里面就同时需要 2 和 3 两个版本的路径:\
    ```
    let g:python_host_prog = '/usr/bin/python'
    let g:python3_host_prog = '/usr/local/bin/python3'
    ```

    另,我们公司产品的开发环境里面,也需要 python2 的路径。

    等等
    70 条回复    2022-05-16 11:58:09 +08:00
    echo1937
        1
    echo1937  
       16 天前   ❤️ 1
    如果是管理环境,miniconda + requirement.txt 是不错的,至于 Py2 我是真的不想写了,这比 Java8 还还牛皮癣。
    AJDX3906
        2
    AJDX3906  
       16 天前 via Android
    anaconda 可以管理多个版本的 python
    tanwill12138
        3
    tanwill12138  
       16 天前
    virtualenv
    duzhor
        4
    duzhor  
       16 天前
    virtualenv +1
    crownor
        5
    crownor  
       16 天前   ❤️ 2
    pyenv ,我感觉用起来是能够最透明的,一次设定后续一直有效,而且用起来和没有虚拟环境一样
    t2jk4000
        6
    t2jk4000  
       16 天前
    pyenv
    zyiming1995
        7
    zyiming1995  
       16 天前
    windows 下手动安装多个版本的 python, 然后在每个项目中使用 virtualenv 创建需要版本的虚拟环境; mac 和 linux 使用 pyenv
    Kinnice
        8
    Kinnice  
       16 天前 via Android
    virtualenv
    或者
    直接 python 和 python3
    pip 使用时 python/3 -m pip
    Davic1
        9
    Davic1  
       16 天前
    把环境变量改一下, 运行程序的名称也改一下, python2 就叫 python2 python3 就叫 python3 运行程序的时候直接 python2 xxx.py 或者 python3 xxx.py
    ffxrqyzby
        10
    ffxrqyzby  
       16 天前
    pyenv 无烦恼
    huang119412
        11
    huang119412  
       16 天前   ❤️ 1
    @echo1937 你是魔怔了还是生活不如意啊?说 Python 关 Java 什么事? Java 可没有抛弃向下兼容。
    rationa1cuzz
        12
    rationa1cuzz  
       16 天前
    miniconda 或者 python 和 python3 pip 和 pip3 (如果只有两个版本的话)
    echo1937
        13
    echo1937  
       16 天前   ❤️ 13
    @huang119412 #11 你才是魔怔了,我这两个都写,吐槽一下还需要你批准吗?
    raptor
        14
    raptor  
       16 天前
    我以前是用 virtualevnwrapper ,后来不用 py2 了,现在用 pyenv ,不知道这个 py2 能不能用
    Fantasia1993
        15
    Fantasia1993  
       16 天前
    Python 虚拟环境了解下
    Blunt1991
        16
    Blunt1991  
       16 天前
    个人 pyenv 体验最好
    CrossEntropy
        17
    CrossEntropy  
       16 天前
    个人体验上 anaconda/miniconda 作为 python 的版本管理工具、包管理工具很好用
    leonhao
        18
    leonhao  
       16 天前   ❤️ 1
    2022 了,为啥还用 Python2
    chiu
        19
    chiu  
       16 天前
    pyenv
    c8c
        20
    c8c  
       16 天前
    pyenv
    palm0322
        21
    palm0322  
       16 天前 via iPhone
    miniconda +1
    silkriver
        22
    silkriver  
       16 天前
    pyenv 好像只适用于 *nix ,anaconda 是非 Python 程序员和非程序员的最佳选择
    yazoox
        23
    yazoox  
    OP
       16 天前
    @leonhao 老项目维护。相信你也不愿意花大功夫,去给老的项目升级编译或者运行环境吧?(没有大的需求,或者变动情况下)
    yazoox
        24
    yazoox  
    OP
       16 天前
    可能我没有说清楚,大家好像误会我的意思了。我再补充一点说明。
    谢谢
    exiledkingcc
        25
    exiledkingcc  
       16 天前
    linux 的话,可以随便你安装多个 python ,然后用 python 虚拟环境不就行了。
    18519017871
        26
    18519017871  
       16 天前
    1. 系统全局层面,alias 方式控制两个版本并存,比如 python 默认为 3 ,python2 即版本 2
    2. 单个项目层面,个人使用的 JB 的 IDE 直接抹平了这个版本环境问题,本身单个配置下运行环境
    ospider
        27
    ospider  
       16 天前
    现在还需要 python2 的公司,建议直接辞职……
    Latin
        28
    Latin  
       16 天前   ❤️ 1
    NOTE: You can activate multiple versions at the same time, including multiple versions of Python2 or Python3 simultaneously. This allows for parallel usage of Python2 and Python3, and is required with tools like tox. For example, to instruct Pyenv to first use your system Python and Python3 (which are e.g. 2.7.9 and 3.4.2) but also have Python 3.3.6, 3.2.1, and 2.5.2 available, you first pyenv install the missing versions, then set pyenv global system 3.3.6 3.2.1 2.5.2. Then you'll be able to invoke any of those versions with an appropriate pythonX or pythonX.Y name. You can also specify multiple versions in a .python-version file by hand, separated by newlines. Lines starting with a # are ignored.
    pyenv 正解
    https://github.com/pyenv/pyenv
    Oktfolio
        29
    Oktfolio  
       16 天前
    我之前学 python 就是被这个环境管理劝退的
    mobbdeep
        30
    mobbdeep  
       16 天前
    @ospider 开玩笑,很多赚钱的 py2 老项目跑着都很好,只要能一直赚钱,老板可不管你 2 还是 3
    BBCCBB
        31
    BBCCBB  
       16 天前
    pyenv 好用...
    leonhao
        32
    leonhao  
       16 天前
    @yazoox 如果老板同意我会升级,Python2 社区已经不维护了
    Donahue
        33
    Donahue  
       16 天前
    同时生效也是用 virtual env 就能解决的,你设置路径的时候不要设置 /usr/bin/python , 而是设置成虚拟环境 python 就行了。比如 /virtual/env/path/python 。/usr/bin/python 是个 soft link, 在 activate 虚拟环境的时候指向对应虚拟环境的 python
    gesse
        34
    gesse  
       16 天前
    virtualenv/pyvenv 利用已经安装的 python 版本虚拟出同一个版本的 python 环境,每个环境可以依赖不同版本的包。

    pyenv/anaconda/miniconda 安装不同的 python 版本,且共存

    pyenv-virtualenv 安装不同的 python 版本, 并且支持虚拟环境依赖不同版本的包

    我的理解是这样的,不知道是否有错误观点。
    ospider
        35
    ospider  
       16 天前
    @mobbdeep 用 python2 多赚的钱又不分我,我找下份工作可是不需要 python2 这个技能了……
    liprais
        36
    liprais  
       16 天前 via iPhone
    python2 已经 eol 了都不升级,赚来的钱是准备数据泄漏了交罚款么....
    fkdtz
        37
    fkdtz  
       16 天前
    python 有很多包管理和环境管理工具,搞得人头大。
    但体验下来感觉还是 pyenv + virtualenv 最符合人类直觉,没有那么多花里胡哨。
    pyenv 管理 python 版本做到版本隔离,virtualenv 管理包环境做到项目隔离。
    bo233
        38
    bo233  
       16 天前
    miniconda 还是挺好用的
    anxn
        39
    anxn  
       16 天前
    linux 、mac:pyenv
    Windows:无
    liuxingdeyu
        40
    liuxingdeyu  
       16 天前
    我觉得吧,pyenv+virtualenv 控制环境,py3 和 py2 之间用个进程间通信比如 rpc 啥的,多好
    ynyounuo
        41
    ynyounuo  
       16 天前
    大家完全没有误会你的意思,而是你一直以来以系统 global 为所有项目和程序的 python2/3 依赖的 practice 是最坏的那种而已

    就以你举的 neovim 的例子,官方文档里也是推荐了 pyenv 的
    https://neovim.io/doc/user/provider.html#g:python3_host_prog

    其次比如说你是为了安装 glances 啊 youterm 之类的 global 可执行的东西而非为什么项目或程序做依赖,可以用 pipx ,当然依旧可以 pyenv + 自定义 path / link 来搞定
    Tink
        42
    Tink  
       16 天前
    不影响啊,virtualenv 随便加,不管是 2 还是 3 ,你甚至可以同时应用 10 个不同小版本
    ThirdFlame
        43
    ThirdFlame  
       16 天前
    miniconda 好用,环境独立,也可以复用。 也可以直接以某个虚拟环境进行执行。
    Tink
        44
    Tink  
       16 天前
    举个例子,图里有 2.7 和 3.8 的应用,互不影响,也可以同时使用

    https://cdn.jsdelivr.net/gh/goxofy/[email protected]/2022/05/upgit_20220512_1652323276.png
    princelai
        45
    princelai  
       16 天前
    以前用 virtualenv ,现在换到 miniconda 了,太省事了,以前很多依赖、更新都是自己写脚本
    littlewing
        46
    littlewing  
       16 天前
    conda
    Latin
        47
    Latin  
       16 天前
    个人看法:pyenv + poetry 是目前最好方案
    FengMubai
        48
    FengMubai  
       16 天前
    Windows 下用 scoop, `scoop reset python27`切换版本
    kukat
        49
    kukat  
       16 天前
    以前用 pyenv 管理 python ,nvm 管理 node ,rbenv 管理 ruby...

    现在 asdf 一把唆 https://asdf-vm.com/
    ZztGqk
        50
    ZztGqk  
       16 天前 via iPhone
    pyenv
    mantou99
        51
    mantou99  
       16 天前 via Android
    安装 python 时通过源码编译安装,不要用 apt yum 之类的。
    编译前根据不同版本指定 比如--prefix=/usr/local/python3.7.5 ,--prefix=/usr/local/python3.9.1 。
    理论这样能装所有版本 python ,常用的搞个软连接 ln -s /usr/local/python3.7.5/bin/python3 /usr/bin/python3.7.5
    ln -s /usr/local/python3.7.5/bin/pip3 /usr/bin/pip3.7.5
    要删除的话直接删 /usr/local/python3.7.5
    lolizeppelin
        52
    lolizeppelin  
       16 天前
    python2/3 在红帽 7 以后是共存的
    rpm 包名字都分 python2-和 python3-

    最靠谱的就是用系统包管理...

    因为用系统包管理所以不能用 pip 装任何 python 包,都要用 rpm 包来装,没有 rpm 包自己打包 rpm
    pythonm 的 rpm 包本身就是会基于 pip 编译,spec 文件里写好对应依赖就行

    要么系统全管...要么全自己管不走 rpm
    BingWong
        53
    BingWong  
       16 天前
    可以使用 PDM 管理 python 版本和项目

    https://github.com/pdm-project/pdm
    SenLief
        54
    SenLief  
       16 天前
    如果是多个版本共存的话,你重新命名就好了。软连接都可以。
    shuimugan
        55
    shuimugan  
       16 天前
    没那么复杂,手工都能搞定,python 支持下载 zip 包的,一个目录放一个版本,python 二进制文件原地复制一个,再加到变量里,调用的时候指定具体版本 python 就可以了。
    以 windows 为例,下载不同版本的 zip 包 https://www.python.org/ftp/python/3.10.4/python-3.10.4-embed-amd64.zip ,解压保存
    c:/python/python3.10/python.exe 原地复制一个 python3.10.exe
    c:/python/python3.9/python.exe 原地复制一个 python3.9.exe
    c:/python/python3.8/python.exe 原地复制一个 python3.8.exe
    c:/python/python3.7/python.exe 原地复制一个 python3.7.exe

    至于 pip.exe 官方在 scripts 文件夹里面已经放好了一个 pip3.x 的了,就不需要做了。

    然后把
    c:/python/python3.10/
    c:/python/python3.9/
    c:/python/python3.8/
    c:/python/python3.7/
    追加到环境变量 path 里,然后就可以这样用
    pip3.10 install -r requirements.txt
    python3.10 1.py

    还可以结合 python3.x -m venv 给不同项目做一个依赖包的隔离

    这种方式起码可以 python/php/nodejs/ruby 上
    UN2758
        56
    UN2758  
       16 天前
    miniconda + requirement.txt
    lvzb86
        57
    lvzb86  
       16 天前
    pyenv ,对于文件夹路径的 python 版本进行管理
    zhangneww
        58
    zhangneww  
       16 天前
    居然没人说 pipenv
    zhouu
        59
    zhouu  
       16 天前
    asdf 一把唆 https://asdf-vm.com
    clf
        60
    clf  
       16 天前
    版本 2 重命名为 python2 pip2 (或者是版本 3 的重命名为 python3 pip3 )简单粗暴。
    atttx123
        61
    atttx123  
       16 天前 via iPhone
    pipenv ,一键到位
    AmberMmoe
        62
    AmberMmoe  
       16 天前
    @atttx123 同意这个方案
    lasting
        63
    lasting  
       16 天前
    Miniforge
    Richard14
        64
    Richard14  
       16 天前
    @crownor 看了一下 pyenv 的项目说明,切换体验倒是很类似 conda ,他这个支持像 venv 一样每个项目单独创建一个环境吗?比如我想通过 supervisord 守护一个 py3.8 的项目,应该怎么指定版本是 3.8 呢
    PMR
        65
    PMR  
       15 天前 via Android
    Windows



    py -2 xxx
    py -3 xxx
    coreki
        66
    coreki  
       15 天前
    virtualenv,docker
    crownor
        67
    crownor  
       15 天前
    @Richard14 支持单独创建环境的,比如直接用 pyenv virtualenv 3.8.1 venv_name 这个指令创建名字是 venv_name 的虚拟环境,然后你在当前项目下通过 pyenv local venv_name 就可以了,设置完成之后在当前路径及子路径下的体验就相当于原生 python 一样,完全不用管什么环境的事情了
    crownor
        68
    crownor  
       15 天前
    @Richard14 使用 pyenv 还有一个优势是有很多其他语言的类似环境管理,比如 nodenv 等,基本上熟悉 pyenv 的操作那么其他类似的项目都能快速上手
    supersu
        69
    supersu  
       15 天前 via Android
    @PMR 老哥这个是 win 的正解~
    julyclyde
        70
    julyclyde  
       12 天前
    现在保留 python2 的程序已经是负担了
    关于   ·   帮助文档   ·   API   ·   FAQ   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   1136 人在线   最高记录 5497   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 31ms · UTC 19:46 · PVG 03:46 · LAX 12:46 · JFK 15:46
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.