Python 虚拟环境管理库 - Poetry
简介
Poetry 是虚拟 Python 中的依赖管理和打包工具,它允许你声明项目所依赖的环境库,并为你管理它们。管理
相比于 Pipev,虚拟我觉得 poetry 更加清爽,环境显示更友好一些,管理虽然它的虚拟打包发布我们一般不使用,但是环境其他的虚拟环境管理也是非常方便的。
安装
pip install poetry在控制台执行 poetry -V 命令查看版本

升级
poetry self updatepoetry 配置
在使用 poetry 之前我们先进行一些设置,管理主要是虚拟调整一下虚拟环境的安装位置
设置项
cache-dir
Type: string
缓存目录配置,使用 poetry 安装的环境包源文件都会缓存到这个目录。以下是管理系统默认目录:
macOS: ~/Library/Caches/pypoetry Windows: C:\Users\AppData\Local\pypoetry\Cache Unix: ~/.cache/pypoetryinstaller.parallel
Type: boolean
此配置会被忽略
virtualenvs.create
Type: boolean
默认为true,如果当前工程的虚拟虚拟环境不存在,就创建一个
virtualenvs.in-project
Type: boolean
None:poetry 会在系统特定目录创建一个.venv目录,环境由下面的管理 path 参数指定 true: poetry 会在项目根目录创建一个.venv目录,我推荐这种方式,在项目根目录创建虚拟环境,这样就算移动目录位置也不影响虚拟环境的使用 false: poetry 将会忽略已存在的.venv目录在 Pipev 中如果想把虚拟环境安装在当前工程根目录下,云服务器则需要通过配置环境变量 PIPENV_VENV_IN_PROJECT
virtualenvs.path
Type: string
默认是{cache-dir}/virtualenvs,虚拟环境创建的目录,如果上面的 in-project 为 true,此配置就无效
配置命令
查看所有配置
poetry config --list查询单个配置
poetry config virtualenvs.path添加或者更新配置
poetry config virtualenvs.in-project true删除配置
poetry config virtualenvs.path --unset基本使用
初始化工程
创建新工程
poetry new poetry-demo已存在的工程
cd pre-existing-project poetry init创建成功后将得到如下目录:
poetry-demo- ├── pyproject.toml ├── README.rst ├── poetry_demo │ └── __init__.py └── tests ├── __init__.py └── test_poetry_demo.pypyproject.toml会是一个非常重要的文件,包含了工程的配置和依赖库信息,其初始内容如下:
[tool.poetry] name = "poetry-demo" version = "0.1.0" description = "" authors = ["xingxingzaixian <beixia1989@163.com>"] [tool.poetry.dependencies] python = "^3.7" [tool.poetry.dev-dependencies] pytest = "^5.2" [build-system] requires = ["poetry-core>=1.0.0"] build-backend = "poetry.core.masonry.api"指定虚拟环境的 pypi 源
[[tool.poetry.source]] name = "custom" url = "https://pypi.tuna.tsinghua.edu.cn/simple" default = truepyproject.toml 文件配置介绍
tool.poetry
name项目名称,必选
version项目版本号,默认0.1.0,必选
description项目描述,必选
license开源协议
authors作者,这是一个列表,至少需要包含一个作者信息,必选
maintainers维护者
readmeREADME文件
homepage项目首页地址
基本命令
new
# 创建新项目 poetry new projectinit
# 初始化已存在的项目 poetry init project可选项:
--name: 名称. --description: 描述. --author: 作者. --python: Python 版本. --dependency: 要使用版本约束的包. 格式应该为 foo:1.0.0. --dev-dependency: 开发需求install
poetry installinstall 命令从当前项目读取 pyproject.toml 文件中的依赖性并安装它们。
如果当前目录中有poetry.lock文件,它将使用其中的确切版本,而不是解析它们。这确保使用库的每个人都将获得相同版本的依赖项。亿华云计算如果没有poetry.lock文件,poetry将在依赖项解析后创建一个。
update
升级安装包
add
poetry add requests # ==> pip install requests poetry add requests@^2.20.0 # 安装大于2.20.0版本的包 poetry add "requests=2.20.0" # ==> pip install requests==2.20.0 poetry add "uvicorn[standard]" # ==> pip install uvicorn[standard] # 从 git 仓库安装 poetry add git+https://github.com/sdispater/pendulum.git poetry add git+ssh://git@github.com/sdispater/pendulum.git poetry add git+https://github.com/sdispater/pendulum.git#develop poetry add git+https://github.com/sdispater/pendulum.git#2.0.5 # 从本地文件安装 poetry add ./my-package/ poetry add ../my-package/dist/my-package-0.1.0.tar.gz poetry add ../my-package/dist/my_package-0.1.0.whl安装依赖库并添加到 pyproject.toml,如果没有指定版本约束,就安装最新版本
remove
poetry remove删除已经安装的依赖包
show
# 显示已经安装的包和版本号 poetry show # 显示非开发环境的安装包 poetry show --no-dev # 显示依赖包的层级关系 poetry show --tree # 显示已安装包的当前版本和最新版本 poetry show -l # 显示可更新的包 poetry show -orun
这个命令也是一个比较重要的命令,可以让我们不进入虚拟环境就执行虚拟环境内的命令
# 查询虚拟环境内的 Python 版本 poetry run python -V # 执行虚拟环境内的脚本 poetry run python test.py除了以上可以直接执行python命令外,我们还可以配置自定义的脚本命令,在 pyproject.toml 文件中配置 [tool.poetry.scripts],例如配置:
[tool.poetry.scripts] test = "python test.py" serve = "python run.py"可以执行以下命令:
poetry run serveshell
# 进入虚拟环境内 poetry shellcheck
# 检查 pyproject.toml 配置是否正确 poetry checksearch
# 查询包 poetry search requestsexport
# 将依赖包导出为 requirements.txt 格式,导出文件名为 requirements.txt poetry export -f requirements.txt --output requirements.txtenv
# 使用指定环境的python poetry env use /full/path/to/python # 如果python在环境变量中,可以使用一下方式指定 poetry env use python3.7 # 显示当前虚拟环境信息 poetry env info # 仅显示虚拟环境的路径 poetry env info --path # 显示当前工程的所有虚拟环境列表 poetry env list # 显示当前工程的虚拟环境绝对路径 poetry env list --full-path # 删除虚拟环境 poetry env remove /full/path/to/python poetry env remove python3.7cache
# 查看缓存列表 poetry cache list # 清除指定的缓存 poetry cache clear <cache> # 清除所有缓存 poetry cache clear --all依赖包的版本关系
在 poetry 中支持类似 webpack 里面的版本关系,例如 ^2.3.0、服务器托管~2.3.0,这是什么对应关系呢

相关文章
利用无peu盘装系统的教程及技巧(无peu盘装系统,实现简单高效,方便快捷安装)
摘要:在计算机安装系统时,通常需要使用peu盘来进行引导和安装。然而,对于一些没有peu盘的情况下,我们也可以通过一些技巧和方法来完成系统的安装,本文将详细介绍以无peu盘装系统的教程。...2025-11-04
我叫道延, 2014 年加入阿里,在阿里通信工作了近两年。2016 年年底加入业务平台团队,当时 Leader 找我的第一件事就是要解决大促的问题,第二件事就是解决安全生产的问题。我带着这个命题进入业2025-11-04
本文是在React中的高优先级任务插队机制基础上的后续延伸,先通过阅读这篇文章了解任务调度执行的整体流程,有助于更快地理解本文所讲的内容。饥饿问题说到底就是高优先级任务不能毫无底线地打断低优先级任务,2025-11-04
文章转载自微信公众号“早起Python”(zaoqi-python)。大家好,又到了Python办公自动化(偷懒)专题。今天介绍的案例是如何利用Python来自动化移动、修改、重命名文件/夹,这样的操2025-11-04- 摘要:随着科技的不断发展,越来越多的人需要在不同设备之间进行远程访问和控制。而远程桌面设置是实现这一需求的重要方法之一。本文将为大家介绍如何通过简单操作实现远程访问。什么是远程桌...2025-11-04

重磅推荐!我在Github上找到一个超级轻量、灵活的SQL工具
今天和大家推荐一款轻量级但功能强大的 SQL 工具,带有 notebook 界面。无需安装和注册,即可快速安全地使用数据——Franchise。目前,Franchise在Github上标星 3.7K,2025-11-04


最新评论