问题:如何使用Pipfile和Pipfile.lock?
在Python封装的上下文中,似乎Pipfile / Pipfile.lock旨在替代Requirements.txt。但是,关于它们如何实际工作的文献很少。我在这里的Python网站的PyPi部分找到了对pipfile的不断发展的描述,但这很混乱,并且没有解释文件不同部分的语义。
关于如何理解这些文件的任何指示?
回答 0
如果您对Ruby的Bundler或Node的Npm有一定的了解,这些文件的概念很简单,并且与其他现有工具类似。Pipenv
是使用Pipfile和Pipfile.lock文件实现这些目标的程序包和虚拟环境管理工具。
Pipenv以一种默认的标准方式为您处理虚拟环境(不再需要激活和停用)。下面是一些入门的基础知识,请在pipenv网站上查看更多信息。
入门
在您的项目文件夹类型中,开始使用pipenv很容易。
$ pipenv install
…,如果已经有一个requirements.txt
文件,它将生成一个Pipfile
带有需求的文件和一个虚拟环境文件夹,否则,它将生成一个空Pipfile
文件。如果您不喜欢或改变主意,请输入…
$ pipenv uninstall <package>
…而且您很高兴。要激活已生成pipenv的虚拟环境,请继续…
$ pipenv shell
…,您的虚拟环境将被激活。离开环境…
$ exit
…,您将回到原来的终端会话。
点文件
该Pipfile文件旨在指定套餐要求为您的Python应用程序或库,既要发展和执行。您只需使用…即可安装软件包。
$ pipenv install flask
…并将其添加为部署和执行的依赖项或使用…
$ pipenv install --dev pytest
…,它将用作开发时间的依赖。文件语法非常简单,如下所示。
[[source]] # Here goes your package sources (where you are downloading your packages from).
url = "https://pypi.python.org/simple"
verify_ssl = true
name = "pypi"
[packages] # Here goes your package requirements for running the application and its versions (which packages you will use when running the application).
requests = "*"
flask = "*"
pandas = "*"
[dev-packages] # Here goes your package requirements for developing the application and its versions (which packaes you will use when developing the application)
pylint = "*"
wheel = "*"
[requires] # Here goes your required Python version.
python_version = "3.6"
Pipfile.lock
该Pipfile.lock是用来规定的基础上,目前在包装Pipfile,应使用哪个那些特定版本,避免自动升级依赖于对方的包和破坏你的项目的依赖关系树的风险。
您可以使用…锁定当前安装的软件包。
$ pipenv lock
…,然后该工具将根据当前安装的版本查找您的虚拟环境文件夹,以自动为您生成锁定文件。文件语法并不像Pipfile那样明显,因此为简洁起见,此处不会显示。