Python 3.3在其标准库中包含了新的软件包venv。它做什么,它与所有其他匹配regex(py)的包有何不同?(v|virtual|pip)?环境?


当前回答

2020年1月更新

@Flimm很好地解释了所有的差异。通常,我们想知道所有工具之间的区别,因为我们想决定什么对我们最有利。所以,下一个问题是:使用哪一个?我建议您选择两种管理虚拟环境的官方方式之一:

Python Packaging现在推荐PipenvPython.org现在推荐venv

其他回答

pyenv-管理不同的python版本,所有其他-创建虚拟环境(它隔离了python版本和安装的“要求”),

pipenv希望合并所有内容,除了之前的内容,它还将“需求”安装到活动虚拟环境中或创建自己的如果没有激活)

所以也许你只会对pipenv感到高兴。

但我使用:pyenv+pyenv virtualenvwrapper,+pipenv(pipenv仅用于安装需求)。

在Debian中:

apt安装libffi-dev安装pyenv基于https://www.tecmint.com/pyenv-install-and-manage-multiple-python-versions-in-linux/但是..而不是pyenv virtualenv安装pyenv虚拟vwrapper(它可以是独立的库或pyenv插件,这里是第二个选项):$pyenv安装3.9.0$git克隆https://github.com/pyenv/pyenv-virtualenvwrapper.git$(pyenv根)/plugins/pyenv虚拟vwrapper#在~/.bashrc中添加:#export$VIRTUALENVRAPPER_PYTHON=“/usr/bin/python3”$source~/.bashrc$pyenv虚拟vwrapper

然后为项目创建虚拟环境(workingdir必须存在):

pyenv local 3.9.0  # to prevent 'interpreter not found' in mkvirtualenv
python -m pip install --upgrade pip setuptools wheel
mkvirtualenv <venvname> -p python3.9 -a <workingdir>

并在项目之间切换:

workon <venvname>
python -m pip install --upgrade pip setuptools wheel pipenv

在一个项目中,我有文件requirements.txt,但没有修复其中的版本(如果不需要某些版本限制)。您有两种可能的工具将它们安装到当前虚拟环境中:pip工具或pipenv。假设您将使用pipenv:

pipenv install -r requirements.txt

这将创建Pipfile和Pipfile.lock文件,固定版本在第二个版本中。如果您想在完全相同的地方重新安装(必须存在Pipfile.lock):

pipenv install

请记住,Pipfile.lock与某些Python版本相关,如果使用其他版本,则需要重新创建。

正如你所看到的,我写了requirements.txt。这有一些问题:你也必须从Pipfile中删除一个已删除的包。所以直接编写Pipfile可能更好。

所以你可以看到我用pipenv很差。也许如果你好好使用它,它可以取代一切?

编辑2021.01:我已将堆栈更改为:pyenv+pyenv virtualenvwrapper+poetry。我没有使用apt或pip安装virtualenv或virtualvwrapper,而是安装pyenv的插件pyenv virtualvwrappr。这是比较容易的方法。

诗歌对我来说很棒:

poetry add <package>   # install single package
poetry remove <package>
poetry install   # if you remove poetry.lock poetry will re-calculate versions

这是我对初学者的个人建议:首先学习virtualenv和pip,这两种工具可以在Python 2和3以及各种情况下使用,一旦您开始需要它们,就可以选择其他工具。

现在来回答这个问题:这些名称相似的东西之间有什么区别:venv、virtualenv等?

不在标准库中的PyPI包:

virtualenv是一个非常流行的工具,它为Python库创建独立的Python环境。如果你不熟悉这个工具,我强烈建议你学习它,因为它是一个非常有用的工具。它的工作方式是在一个目录中安装一堆文件(例如:env/),然后修改PATH环境变量,以在其前面加上一个自定义bin目录(例如:nv/bin/)。python或python3二进制文件的精确副本放在这个目录中,但python被编程为首先在环境目录中查找与其路径相关的库。它不是Python标准库的一部分,但得到了PyPA(Python打包管理局)的正式批准。激活后,您可以使用pip在虚拟环境中安装软件包。pyenv用于隔离Python版本。例如,您可能希望针对Python 2.7、3.6、3.7和3.8测试代码,因此需要在它们之间切换。一旦激活,它就会在PATH环境变量前面加上~/.pyenv/shims,其中有与Python命令(Python、pip)匹配的特殊文件。这些不是Python附带命令的副本;它们是一种特殊的脚本,可以根据PYENV_version环境变量、.Python版本文件或~/.PYENV/version文件随时决定运行哪个版本的Python。pyenv还使用命令pyenv install使下载和安装多个Python版本的过程更容易。pyenvvirtualenv是pyenv的一个插件,与pyenv作者相同,可以方便地同时使用pyenv和virtualenv。然而,如果您使用的是Python 3.3或更高版本,pyenv virtualenv将尝试运行Python-m venv(如果可用),而不是virtualenv。如果您不想使用方便的特性,可以在不使用pyenv virtualenv的情况下同时使用virtualenv和pyenv。virtualvwrapper是virtualenv的一组扩展(参见文档)。它为您提供了mkvirtualenv、lssitepackages等命令,尤其是在不同virtualenv目录之间切换的工作。如果您需要多个virtualenv目录,此工具特别有用。pyenv virtualenvwrapper是pyenv的一个插件,与pyenv作者相同,可以方便地将virtualnvwrapper集成到pyenv中。pipenv旨在将Pipfile、pip和virtualenv组合成命令行上的一个命令。virtualenv目录通常放在~/.local/share/virtalenvs/XXX中,其中XXX是项目目录路径的哈希。这与virtualenv不同,virtualenv中的目录通常位于当前工作目录中。pipenv用于开发Python应用程序(而不是库)。pipenv还有其他选择,例如诗歌,我不会在这里列出,因为这个问题只涉及名称类似的包。

标准库:

pyvenv(不要与上一节中的pyenv混淆)是Python 3.3到3.7附带的脚本。它被从Python 3.8中删除,因为它有问题(更不用说令人困惑的名称)。运行python3-m-venv的效果与pyvenv完全相同。venv是Python 3附带的一个软件包,您可以使用python3-m venv运行该软件包(尽管出于某些原因,一些发行版将其分离为一个单独的发行版软件包,例如Ubuntu/Debian上的python3 venv)。它的作用与virtualenv相同,但只有一部分特性(请参阅此处的比较)。virtualenv仍然比venv更受欢迎,特别是因为前者同时支持Python2和3。

让我们从这些工具要解决的问题开始:

我的系统包管理器没有我想要的Python版本,或者我想并排安装多个Python版本,Python 3.9.0、Python 3.9.1、Python 3.5.3等

然后使用pyenv。

我想安装和运行多个具有不同、冲突依赖关系的应用程序。

然后使用virtualenv或venv。这些几乎是完全可互换的,不同的是,virtualenv支持较旧的python版本,并具有一些较小的独特功能,而venv在标准库中。

我正在开发一个/application/,需要管理我的依赖关系,并管理项目依赖关系的依赖关系解析。

然后使用pipenv或诗歌。

我正在开发/library/或/package/,并希望指定库用户需要安装的依赖项

然后使用setuptools。

我使用了virtualenv,但我不喜欢virtualenv文件夹分散在各个项目文件夹中。我想要集中管理环境和一些简单的项目管理

然后使用virtualvwrapper。变体:pyenv virtualenvwrapper,如果您也使用pyenv。


不推荐使用

皮文夫。这是不推荐的,请改用venv或virtualenv。不要与pipenv或pyenv混淆。

我想将docker添加到这个列表中,以及几个答案已经提到的conda。

conda比标题中提到的虚拟环境更重。它还隔离了一些系统python工具,如ffmpeg或gpu驱动程序。

docker甚至更好,它为您提供了一个全新的操作系统。有了一个好的Dockerfile和一个docker构建、docker运行脚本,您就可以很好地记录环境是如何构建的,并且很容易填充、迁移到其他环境(登台、生产、云)。从长远来看,它会帮助你。

另一件事:PyCharm提供了几个选项来选择您的虚拟环境。这有助于新来者不必担心这件事。建议在了解虚拟环境是什么之前使用它。

作为一个Python新手,这个问题让我沮丧不已,困惑了好几个月。当我知道我将在未来几年使用虚拟环境和软件包管理器时,我应该在学习中投资哪些虚拟环境和程序包管理器?

回答这个棘手问题的最佳文章是https://jakevdp.github.io/blog/2016/08/25/conda-myths-and-misconceptions/杰克·范德普拉斯。虽然已经有几年的历史,但它提供了实用的答案,以及Python包和虚拟环境管理器的历史,因为这些最先进的软件正在开发中。

在数据科学和“大数据云计算”社区,这对我来说尤其令人沮丧,因为conda被广泛用作Python和JavaScript、SQL、Java、HTML5和Jupyter笔记本的虚拟环境管理器和全功能包管理器。

那么,当conda完成了pip和venv变体的所有功能时,为什么还要使用pip呢?

答案是,“因为如果conda包根本不可用,您必须使用pip。”很多时候,所需的包只能以pip格式提供,除了使用pip之外,没有简单的解决方案。您可以学习使用conda构建,但如果您不是包维护者,那么您必须说服包所有者为每个新版本生成一个conda包(或者自己动手)

这些基于pip的软件包在许多重要和实用的方面有所不同:

稳定性成熟复杂性积极支持(对死亡或死亡)Python生态系统“核心”与“边缘”(即,集成到Python.org发行版中)易于理解和使用(适用于初学者)

我将从软件包成熟度和稳定性的角度回答您关于两个软件包的问题。

venv和virtualenv是最成熟、稳定和社区支持的。从在线文档中可以看到,截至目前,virtualenv的版本为20.x。虚拟的

virtualenv是一个创建独立Python环境的工具。自从Python 3.3,它的一个子集已集成到标准中venv模块下的库。venv模块不提供所有功能该库的功能,仅举几个更突出的功能:速度较慢(通过不使用应用数据种子方法),不可延伸,无法为任意安装的python版本创建虚拟环境(并自动发现这些),不能通过pip升级,没有丰富的编程API(描述虚拟环境而不创建它们)。

virtualenvwrapper是一套帮助人们使用virtualenv的脚本(它是一个维护不好的“包装器”,上一次更新是在2019年)。虚拟说唱歌手

我的建议是尽可能避免所有pip虚拟环境。改用conda。Conda提供了一种统一的方法。它由专业开源开发者团队维护,并有一家声誉良好的公司提供资金和商业支持版本。相比之下,维护pip、venv、virtualenv、pipenv和许多其他pip变体的团队资源有限。pip虚拟环境的多样性对于初学者来说是令人沮丧的。基于pip的虚拟环境工具的复杂性、碎片化、边缘化和不受支持的包,以及极不一致的支持,驱使我使用conda。对于数据科学工作,我的建议是,当conda包不存在时,使用基于pip的虚拟环境管理器作为最后的手段。

venv变体之间的差异仍然让我感到害怕,因为我学习新软件包的时间有限。pipenv、venv、pyvenv、pyenv、virtualenv、virtualenvwrapper、poetry和其他人有许多不同之处和复杂性,需要几天才能理解。我讨厌走上一条路,当维护人员辞职(或太忙而无法维护)时,为软件包找到支持。我只需要完成我的工作。

本着乐于助人的精神,这里有几个链接可以帮助你深入了解,但不要迷失在但丁的《地狱》(re:pip)中。

Python虚拟环境指南

选择“核心”Python包来投资于你的职业(长期),而不是短期内完成工作,这一点很重要。然而,这是一个商业分析问题。你是想简单地完成一项任务,还是想找一个专业的软件工程师来构建一个可扩展的高性能系统,并且随着时间的推移需要最少的维护工作量?我的天,conda将带你去后一个地方比处理pip复数问题更容易。conda仍然缺少一步pip包迁移工具,这使得这成为一个悬而未决的问题。如果我们可以简单地将pip包转换为conda包,那么pypi.org和conda forge可以合并。Pip是必要的,因为conda包还没有普及。许多Python程序员要么懒得创建conda包,要么他们只使用Python编程,不需要conda的语言不可知/多语言支持。

conda对我来说是一个天赐良机,因为它支持云软件工程和数据科学对JavaScript、SQL和Jupyter Notebook扩展的多语言支持,并且conda在Docker和其他云原生环境中运行良好。我鼓励您学习并掌握conda,这将使您能够回避许多基于pip的工具可能永远无法回答的复杂问题。

保持简单!我需要一个能满足我90%需求的软件包,并为剩下的10%的边缘案例提供指导和解决方案。

查看此处链接的文章,了解有关基于pip的虚拟环境的更多信息。

我希望这对原始海报有帮助,并给琵琶和康达爱好者一些思考的东西。