Poetry 是 Python 中的依赖管理和打包工具,它允许你声明项目所依赖的库,并为你管理它们。
我们提供的服务有:成都做网站、网站建设、微信公众号开发、网站优化、网站认证、丰南ssl等。为数千家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的丰南网站制作公司
相比于 Pipev,我觉得 poetry 更加清爽,显示更友好一些,虽然它的打包发布我们一般不使用,但是其他的虚拟环境管理也是非常方便的。
- pip install poetry
在控制台执行 poetry -V 命令查看版本
- poetry self update
在使用 poetry 之前我们先进行一些设置,主要是调整一下虚拟环境的安装位置
Type: string
缓存目录配置,使用 poetry 安装的包源文件都会缓存到这个目录。以下是系统默认目录:
Type: boolean
此配置会被忽略
Type: boolean
默认为true,如果当前工程的虚拟环境不存在,就创建一个
Type: boolean
在 Pipev 中如果想把虚拟环境安装在当前工程根目录下,则需要通过配置环境变量 PIPENV_VENV_IN_PROJECT
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.py
pyproject.toml会是一个非常重要的文件,包含了工程的配置和依赖库信息,其初始内容如下:
- [tool.poetry]
- name = "poetry-demo"
- version = "0.1.0"
- description = ""
- authors = ["xingxingzaixian
"] - [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"
- [[tool.poetry.source]]
- name = "custom"
- url = "https://pypi.tuna.tsinghua.edu.cn/simple"
- default = true
tool.poetry
项目名称,必选
项目版本号,默认0.1.0,必选
项目描述,必选
开源协议
作者,这是一个列表,至少需要包含一个作者信息,必选
维护者
README文件
项目首页地址
- # 创建新项目
- poetry new project
- # 初始化已存在的项目
- poetry init project
可选项:
- poetry install
install 命令从当前项目读取 pyproject.toml 文件中的依赖性并安装它们。
如果当前目录中有poetry.lock文件,它将使用其中的确切版本,而不是解析它们。这确保使用库的每个人都将获得相同版本的依赖项。如果没有poetry.lock文件,poetry将在依赖项解析后创建一个。
升级安装包
- 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,如果没有指定版本约束,就安装最新版本
- poetry remove
删除已经安装的依赖包
- # 显示已经安装的包和版本号
- poetry show
- # 显示非开发环境的安装包
- poetry show --no-dev
- # 显示依赖包的层级关系
- poetry show --tree
- # 显示已安装包的当前版本和最新版本
- poetry show -l
- # 显示可更新的包
- poetry show -o
这个命令也是一个比较重要的命令,可以让我们不进入虚拟环境就执行虚拟环境内的命令
- # 查询虚拟环境内的 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 serve
- # 进入虚拟环境内
- poetry shell
- # 检查 pyproject.toml 配置是否正确
- poetry check
- # 查询包
- poetry search requests
- # 将依赖包导出为 requirements.txt 格式,导出文件名为 requirements.txt
- poetry export -f requirements.txt --output requirements.txt
- # 使用指定环境的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.7
- # 查看缓存列表
- poetry cache list
- # 清除指定的缓存
- poetry cache clear
- # 清除所有缓存
- poetry cache clear --all
在 poetry 中支持类似 webpack 里面的版本关系,例如 ^2.3.0、~2.3.0,这是什么对应关系呢
文章名称:Python虚拟环境管理库-Poetry
标题URL:http://www.shufengxianlan.com/qtweb/news8/543408.html
成都网站建设公司_创新互联,为您提供软件开发、微信小程序、网站策划、搜索引擎优化、ChatGPT、App设计
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联