0

0

Python包管理:深入理解pipx与pip在库安装中的正确实践

心靈之曲

心靈之曲

发布时间:2025-11-14 11:36:01

|

417人浏览过

|

来源于php中文网

原创

python包管理:深入理解pipx与pip在库安装中的正确实践

本文旨在阐明Python包管理工具`pipx`和`pip`的不同用途与最佳实践。我们将探讨为何`pipx`安装的库无法直接导入,并详细指导如何利用虚拟环境(如`venv`)与`pip`正确安装和管理项目依赖库,以避免常见的`ModuleNotFoundError`。

在Python生态系统中,包管理是日常开发不可或缺的一部分。pip作为Python的官方包安装工具,被广泛用于安装和管理项目依赖库。然而,随着Python工具链的演进,出现了像pipx这样专门用于安装Python应用程序的工具,这有时会导致开发者在使用时产生混淆。理解这两个工具的核心差异,对于高效且无误地管理Python环境至关重要。

pipx的作用与特性

pipx是一个专门用于在隔离环境中安装和运行Python应用程序的工具。它的核心理念是将Python应用程序安装到独立的虚拟环境中,然后将这些应用程序的可执行脚本链接到用户的PATH中,使其可以像系统命令一样全局调用。这样做的好处是:

  1. 环境隔离: 每个应用程序都拥有自己的独立环境,避免了不同应用程序之间依赖冲突的问题。
  2. 全局可用: 应用程序可以从任何位置直接通过其名称运行,无需激活特定的虚拟环境。
  3. 不污染系统环境: 应用程序及其依赖不会直接安装到系统Python环境中,保持系统环境的清洁。

使用示例:

立即学习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安装的库无法导入

尽管pipx成功安装了binance-connector,并可能将其中的某些脚本作为全局应用程序暴露,但它并非设计用于安装可供其他Python脚本通过import语句导入的库。

pipx为每个应用程序创建的是一个独立的、隔离的虚拟环境。当你在终端中直接运行python3.11并尝试导入binance模块时,这个Python解释器运行在其自身的默认环境(或你当前激活的任何虚拟环境)中,它并不知道pipx为binance-connector创建的那个独立虚拟环境的存在。因此,它无法找到binance模块,导致ModuleNotFoundError。

简而言之,pipx的目的是将Python“应用程序”转化为系统命令,而不是将Python“库”添加到你的Python解释器搜索路径中。

正确安装可导入库的方法:使用虚拟环境与pip

要解决ModuleNotFoundError并正确地在项目中导入Python库,我们应该遵循Python的最佳实践:为每个项目创建独立的虚拟环境,并使用pip在该环境中安装项目所需的库。

以下是使用venv(Python标准库中的虚拟环境模块)来管理项目依赖的步骤:

1. 创建项目目录(可选)

首先,为你的项目创建一个目录并进入:

GradPen论文
GradPen论文

GradPen是一款AI论文智能助手,深度融合DeepSeek,为您的学术之路保驾护航,祝您写作顺利!

下载
mkdir my_binance_project
cd my_binance_project

2. 创建并激活虚拟环境

在项目目录中,使用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)),表明你当前的操作都在这个隔离环境中进行。

3. 在虚拟环境中安装库

现在,你可以在激活的虚拟环境中使用pip来安装binance-connector库:

pip install binance-connector

pip会将库及其依赖安装到当前激活的虚拟环境中。

4. 验证库是否可导入

安装完成后,你可以在这个激活的虚拟环境中启动Python解释器,并尝试导入binance模块:

python

在Python交互式环境中:

>>> from binance.spot import Spot
>>> # 如果没有报错,说明导入成功

此时,你应该能够成功导入binance模块,而不会遇到ModuleNotFoundError。

5. 退出虚拟环境

当你完成项目开发或需要切换到其他项目时,可以使用deactivate命令退出当前的虚拟环境:

deactivate

总结与最佳实践

理解pipx和pip在Python包管理中的不同定位是至关重要的:

  • pipx: 专注于安装和管理Python应用程序,使其作为系统命令全局可用,且每个应用拥有独立的隔离环境。适用于工具类应用,如black、flake8、httpie等。
  • pip (结合虚拟环境): 专注于安装和管理Python库,作为特定项目的依赖项。通过为每个项目创建独立的虚拟环境(如使用venv、pipenv或poetry),可以确保项目依赖的隔离性、可复现性和避免冲突。

最佳实践:

  • 项目开发: 始终为每个Python项目创建并激活一个虚拟环境,然后使用pip在该环境中安装所有项目依赖库。
  • 全局工具: 对于那些你希望在命令行中直接运行的Python工具(例如代码格式化工具、CLI客户端),可以考虑使用pipx进行安装。
  • 避免混淆: 不要尝试用pipx安装的库在项目代码中进行import,反之亦然。明确两者的职责。

通过遵循这些实践,你将能够更清晰、更有效地管理Python环境和项目依赖,从而避免常见的模块导入错误,提升开发效率。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

339

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

412

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

761

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

349

2025.07.23

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

739

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1128

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

799

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

454

2023.08.02

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.9万人学习

Git 教程
Git 教程

共21课时 | 3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号