python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > poetry安装依赖

python中poetry安装依赖

作者:hola173841439

本文主要介绍了Poetry工具及其在Python项目中的安装和使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前言

Poetry 是一个用于管理 Python 项目的依赖和构建过程的工具。它简化了包管理和虚拟环境的创建,让开发者更容易管理项目的依赖关系。它的出现让我们对依赖卸载更干净。

1. 为什么pip install poetry 会造成依赖冲突

直接使用 pip install poetry 安装 Poetry 可能会造成依赖冲突,原因主要是 pip 在全局环境中安装包的方式可能导致多个项目或工具之间的依赖冲突。这些冲突通常发生在以下几种情况下:

1.1 全局环境依赖混淆:

1.2 工具和项目之间的冲突:

1.3 缺乏依赖隔离:

1.4 多出很多额外依赖:

下载之前:

在这里插入图片描述

​下载之后:

在这里插入图片描述

2. 不推荐pipx安装

在这里插入图片描述

这里有个机翻 https://www.tobyblogs.cn/PoetryCn/1/

3. poetry高级安装

3.1 默认安装路径

By default, Poetry is installed into a platform and user-specific directory:

3.2自定义安装

如果您想更改此设置,可以定义 $POETRY_HOME 环境变量:

curl -sSL https://install.python-poetry.org | POETRY_HOME=/etc/poetry python3 -

如果要安装预发行版本,可以通过将 --preview 选项传递给安装脚本或使用 $POETRY_PREVIEW 环境变量来实现:

curl -sSL https://install.python-poetry.org | python3 - --preview
curl -sSL https://install.python-poetry.org | POETRY_PREVIEW=1 python3 -

如果要安装特定版本,可以使用 --version 选项或 $POETRY_VERSION 环境变量:

curl -sSL https://install.python-poetry.org | python3 - --version 1.2.0
curl -sSL https://install.python-poetry.org | POETRY_VERSION=1.2.0 python3 -

4. 安装poetry实战

4.1 下载安装脚本文件

windows+R 输入powershell

然后在powershell中输入:

Invoke-WebRequest -Uri https://install.python-poetry.org -OutFile install-poetry.py

在当前路径下可以看到install-poetry.py被生成

4.2 通过脚本安装poetry

然后通过这个install-poetry.py安装poetry

首先创建自定义文件夹

cd D:\Program Files:
D:
mkdir Poetry

然后切换到install-poetry.py所在的目录,输入以下命令

$env:POETRY_HOME = "D:/Program Files/Poetry"; python install-poetry.py

4.3 配置环境变量

在这里插入图片描述

把poetry安装目录下的bin添加到系统环境变量

PS D:\Program Files\Poetry\bin> Get-ChildItem | Format-List Name, Length, LastWriteTime


Name          : poetry.exe
Length        : 0
LastWriteTime : 2024/8/18 14:09:11

在这里插入图片描述

检查是否安装成功

PS C:\Users\Administrator> poetry --version
Poetry (version 1.8.3)
PS C:\Users\Administrator>

4.4 修改poetry下载的三方包虚拟环境

查看poetry配置

PS C:\Users\Administrator> poetry config --list
cache-dir = "C:\\Users\\Administrator\\AppData\\Local\\pypoetry\\Cache"
experimental.system-git-client = false
installer.max-workers = null
installer.modern-installation = true
installer.no-binary = null
installer.parallel = true
keyring.enabled = true
solver.lazy-wheel = true
virtualenvs.create = true
virtualenvs.in-project = null
virtualenvs.options.always-copy = false
virtualenvs.options.no-pip = false
virtualenvs.options.no-setuptools = false
virtualenvs.options.system-site-packages = false
virtualenvs.path = "{cache-dir}\\virtualenvs"  # C:\Users\Administrator\AppData\Local\pypoetry\Cache\virtualenvs
virtualenvs.prefer-active-python = false
virtualenvs.prompt = "{project_name}-py{python_version}"
warnings.export = true
PS C:\Users\Administrator>

不想让poetry下载的三方包在默认路径下,让他下载到我们自定义的目录。 virtualenvs.in-project 是 Poetry 的一个配置选项,用于决定虚拟环境是否应该放在项目目录内。

virtualenvs.in-project = true: 如果这个选项设置为 true,Poetry 会在项目的根目录下创建一个 .venv 文件夹,并在其中创建虚拟环境。这意味着每个项目都有一个独立的虚拟环境位于项目目录内,便于管理和隔离。

PS C:\Users\Administrator> poetry config virtualenvs.in-project true
PS C:\Users\Administrator> poetry config --list
cache-dir = "C:\\Users\\Administrator\\AppData\\Local\\pypoetry\\Cache"
experimental.system-git-client = false
installer.max-workers = null
installer.modern-installation = true
installer.no-binary = null
installer.parallel = true
keyring.enabled = true
solver.lazy-wheel = true
virtualenvs.create = true
virtualenvs.in-project = true
virtualenvs.options.always-copy = false
virtualenvs.options.no-pip = false
virtualenvs.options.no-setuptools = false
virtualenvs.options.system-site-packages = false
virtualenvs.path = "{cache-dir}\\virtualenvs"  # C:\Users\Administrator\AppData\Local\pypoetry\Cache\virtualenvs
virtualenvs.prefer-active-python = false
virtualenvs.prompt = "{project_name}-py{python_version}"
warnings.export = true

4.5 在老项目中使用poetry

cd myproject
poetry init
poetry init --no-interaction       不适用交互模型,生产的toml文件配置是默认参数

4.6 在新项目中使用poetry

poetry new my_project

到此这篇关于python中poetry安装依赖的文章就介绍到这了,更多相关poetry安装依赖内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

您可能感兴趣的文章:
阅读全文