
本文旨在阐明Python包管理工具`pipx`和`pip`的不同用途与最佳实践。我们将探讨为何`pipx`安装的库无法直接导入,并详细指导如何利用虚拟环境(如`venv`)与`pip`正确安装和管理项目依赖库,以避免常见的`ModuleNotFoundError`。
在Python生态系统中,包管理是日常开发不可或缺的一部分。pip作为Python的官方包安装工具,被广泛用于安装和管理项目依赖库。然而,随着Python工具链的演进,出现了像pipx这样专门用于安装Python应用程序的工具,这有时会导致开发者在使用时产生混淆。理解这两个工具的核心差异,对于高效且无误地管理Python环境至关重要。
pipx是一个专门用于在隔离环境中安装和运行Python应用程序的工具。它的核心理念是将Python应用程序安装到独立的虚拟环境中,然后将这些应用程序的可执行脚本链接到用户的PATH中,使其可以像系统命令一样全局调用。这样做的好处是:
使用示例:
立即学习“Python免费学习笔记(深入)”;
假设我们希望安装一个名为binance-connector的Python应用程序(虽然它更多被用作库,但在此我们以其作为pipx安装的例子)。我们可以使用pipx install命令:
sudo pipx install binance-connector --include-deps
执行上述命令后,pipx会创建一个新的虚拟环境,并将binance-connector及其依赖安装到其中。输出可能会显示类似以下信息:
⚠️ Note: normalizer was already on your PATH at /usr/bin/normalizer
installed package binance-connector 3.5.1, installed using Python 3.11.2
These apps are now globally available
- normalizer
- wsdump
⚠️ Note: '/root/.local/bin' is not on your PATH environment variable. These
apps will not be globally accessible until your PATH is updated. Run `pipx
ensurepath` to automatically add it, or manually modify your PATH in your
shell's config file (i.e. ~/.bashrc).
done! ✨ ? ✨这里的关键在于pipx提示normalizer和wsdump等“应用”现在是全局可用的。它还可能提示需要更新PATH环境变量,以便这些应用程序的执行路径被系统识别。我们可以通过pipx ensurepath来完成此操作:
pipx ensurepath
如果是在sudo环境下安装,可能需要以sudo权限再次运行pipx ensurepath以更新root用户的PATH:
sudo pipx ensurepath
完成这些步骤后,通常需要打开一个新的终端会话或重新登录,以使PATH变量的更改生效。此时,通过pipx安装的应用程序应该可以在命令行中直接运行。
尽管pipx成功安装了binance-connector,并可能将其中的某些脚本作为全局应用程序暴露,但它并非设计用于安装可供其他Python脚本通过import语句导入的库。
pipx为每个应用程序创建的是一个独立的、隔离的虚拟环境。当你在终端中直接运行python3.11并尝试导入binance模块时,这个Python解释器运行在其自身的默认环境(或你当前激活的任何虚拟环境)中,它并不知道pipx为binance-connector创建的那个独立虚拟环境的存在。因此,它无法找到binance模块,导致ModuleNotFoundError。
简而言之,pipx的目的是将Python“应用程序”转化为系统命令,而不是将Python“库”添加到你的Python解释器搜索路径中。
要解决ModuleNotFoundError并正确地在项目中导入Python库,我们应该遵循Python的最佳实践:为每个项目创建独立的虚拟环境,并使用pip在该环境中安装项目所需的库。
以下是使用venv(Python标准库中的虚拟环境模块)来管理项目依赖的步骤:
首先,为你的项目创建一个目录并进入:
mkdir my_binance_project cd my_binance_project
在项目目录中,使用venv模块创建一个新的虚拟环境。通常,虚拟环境会被命名为.venv或venv:
python3.11 -m venv .venv
创建完成后,需要激活这个虚拟环境。激活命令因操作系统的不同而略有差异:
Linux/macOS:
source .venv/bin/activate
Windows (Cmd):
.venv\Scripts\activate.bat
Windows (PowerShell):
.venv\Scripts\Activate.ps1
激活成功后,你的终端提示符前通常会显示虚拟环境的名称(例如,(.venv)),表明你当前的操作都在这个隔离环境中进行。
现在,你可以在激活的虚拟环境中使用pip来安装binance-connector库:
pip install binance-connector
pip会将库及其依赖安装到当前激活的虚拟环境中。
安装完成后,你可以在这个激活的虚拟环境中启动Python解释器,并尝试导入binance模块:
python
在Python交互式环境中:
>>> from binance.spot import Spot >>> # 如果没有报错,说明导入成功
此时,你应该能够成功导入binance模块,而不会遇到ModuleNotFoundError。
当你完成项目开发或需要切换到其他项目时,可以使用deactivate命令退出当前的虚拟环境:
deactivate
理解pipx和pip在Python包管理中的不同定位是至关重要的:
最佳实践:
通过遵循这些实践,你将能够更清晰、更有效地管理Python环境和项目依赖,从而避免常见的模块导入错误,提升开发效率。
以上就是Python包管理:深入理解pipx与pip在库安装中的正确实践的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号