Python 虚拟环境管理库 - poetry(python虚拟环境virtualenv)
off999 2025-05-02 20:39 34 浏览 0 评论
简介
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<username>\AppData\Local\pypoetry\Cache
- Unix: ~/.cache/pypoetry
installer.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
维护者 - readme
README文件 - 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,这是什么对应关系呢
要求 | 允许的版本 |
^1.2.3 | >=1.2.3 <2.0.0 |
^1.2 | >=1.2.0 <2.0.0 |
^1 | >=1.0.0 <2.0.0 |
^0.2.3 | >=0.2.3 <0.3.0 |
^0.0.3 | >=0.0.3 <0.0.4 |
^0.0 | >=0.0.0 <0.1.0 |
^0 | >=0.0.0 <1.0.0 |
~1.2.3 | >=1.2.3 <1.3.0 |
~1.2 | >=1.2.0 <1.3.0 |
~1 | >=1.0.0 <2.0.0 |
相关推荐
- 360影视大全下载2025免费版(下载360影视大全最新版下载安装到手机版)
-
你好朋友360影视大全里的很多视频都是免费的,建议安装最新的360影视大全就可以了打开360视频,搜索自己需要的视频,点击360播放器右下角的下载箭头,即可将视频进行下载,下载完毕之后视频会保存在36...
- 360安全卫士手机版下载(360安全卫士官方免费下载手机版5.5.0)
-
相当靠谱360手机卫士是一款由奇虎网推出的功能强、效果好、受用户欢迎的上网安全软件。360安全卫士拥有查杀木马、清理插件、修复漏洞、电脑体检、保护隐私等多种功能,并独创了“木马防火墙”“360密盘”等...
- deepin和统信uos(统信和deepin的区别)
-
差不多。1Deepin原名LinuxDeepin、deepinos、深度操作系统,于2014年4月改名Deepin。deepin团队基于Qt/C++(用于前端)和Go(用于后端)开发了的全新深度桌...
- 三星驱动(三星驱动板)
-
驱动是必须装的,但不需要单独安装驱动。 1、电脑的所有硬件,必然要装驱动,键盘、鼠标什么的,都是有驱动的。驱动是软件和硬件结合的桥梁。但多数普通常见的硬件,驱动是widnows系统自带的,不需要用户...
- u盘启动杀毒软件(u盘杀毒系统)
-
有,但是主要是专杀工具,全面的综合杀毒软件基本上没有,因为没什么用。 1、放在U盘里的杀毒软件,就是不安装,也不监控,只杀毒的软件。 2、目前的杀毒软件的工作机制,主要是监控,监控电脑不感染病...
- 联想维修站点查询官网(联想 维修 服务网点)
-
您可以在联想的官方网站上查询到附近的授权维修服务点,或者拨打联想的客服电话寻求帮助。在维修服务点,您可以享受到专业的维修服务,包括硬件故障、软件问题、系统优化等方面的维护和维修。维修人员将会根据您的电...
- 电脑不识别移动硬盘(移动硬盘灯亮但不读取)
-
电脑不能识别移动硬盘可能是由于以下原因造成的:1.电脑和硬盘之间的连接首先,可以确保移动硬盘正确连接到电脑上,检查USB接口是否松动或损坏,可以尝试更换USB线或者尝试连接到其他USB接口看是否能够...
- 键盘的win键在哪里(电脑键盘的win键在哪里)
-
win键就是电脑键盘上显示WINDOWS标志的按键。位于CTRL键与ALT键两个键之间,win键的具体位置一般电脑键盘上有左右两个。Windows键是一种特殊的键,通常位于键盘的左下角。它的图案是一个...
- ghost全盘备份步骤图(用ghost怎么进行全盘备份)
-
可以用手动备份到指定分区。一、用一键Ghost还原中的“中文向导”备份开始-程序-一键Ghost-选出“中文向导”,Ghost中文向导-1、备份文件默认是“第1硬盘第1分区”,如果不是,将鼠标指针移...
-
- 键盘的windows键是哪一个(键盘上windows键是哪个键)
-
windows键就是电脑键盘上ctrl键和alt键之间的按键,位于左下角。它带着微软的徽标,跟开始菜单一样的图标,它属于辅助按键,主要与其它按键组合使用,实现一些特定的功能,组合成多种快捷操作方式。这里上面所知的Win键其实就是键盘上的Wi...
-
2025-12-31 10:51 off999
- win10打开设置快捷键(win10打开设置快捷键是什么)
-
1、首先打开电脑,在任务栏的语言地方点击一下再点击语言首选项。2、然后在新的界面里点击选择左侧“高级设置”按钮。3、之后在新的界面里点击选择“更改语言栏热键”按钮。4、然后在新的界面里点击选择“更改热...
- flash插件下载手机版下载安装
-
华为手机的最新系统版本已经不再支持FlashPlayer,这是由于Adobe已于2020年底停止更新和支持FlashPlayer。因此,如果您使用最新的华为手机系统,可能无法安装和使用Flash...
- 官方应用商店下载(小米官方应用商店下载)
-
1.审核和验证:应用商店会对应用进行审核和验证,确保其质量和可靠性。开发者需要满足一定的要求才能在应用商店上架应用。而官网下载的应用没有经过此类审核和验证,因此用户需要自行评估其质量和可信度。2....
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
