Python 高手编程系列二百四十六:setup.py develop 或 pip -e

使用 setup.py install 安装的包会被复制到当前环境的 site-packages 目录下。也
就是说,无论何时你修改了包的源代码,都需要重新安装它。这常常是集中开发过程中的
一个问题,因为很容易忘记需要再次执行安装。这就是为什么 setuptools 提供了一个额
外的 develop 命令,允许我们在开发模式(development mod)下安装包。这个命令在部
署目录(site-packages)中创建一个指向项目源代码的特殊链接,而不是将整个包复制过去。
可以编辑包的源代码而无需重新安装,并且它在 sys.path 中可用,就像正常安装一样。
pip 也可以用这种模式来安装包。这个安装选项叫作可编辑模式(editable mode),可
以使用 install 命令的-e 参数来启用,代码如下:
pip install -e
命名空间包
Python 之禅(The Zen of Python,你可以在解释器会话中输入 import this 来阅读)
中关于命名空间的说法如下:
命名空间是一个绝妙的想法,我们要多加利用!
这句话至少可以用两种方式来理解。第一种是语言上下文中的命名空间。我们都使用
命名空间,甚至不知道以下内容。
• 模块的全局命名空间。
• 函数或方法调用的本地命名空间。
• 内置名称的命名空间。
另一种命名空间可以在包的层面提供。它们就是命名空间包(namespace packages)这通
常是一个被忽略的功能,在你的组织中或者非常大的项目中对于构建打包生态系统非常有用。
为什么有用
可以将命名空间包理解成在高于元包(meta-package)的层面对相关的包或模块进行分
组的方法,其中每个包都可以单独安装。
如果你的应用组件的开发、打包和版本化都是独立的,但仍然希望从同一个命名空间访问
它们,那么命名空间包特别有用。这有助于明确每个包所属的组织或项目。例如,对于某个虚
构的 Acme 公司,共同的命名空间可以是 acme。结果可能导致创建通用的 acme 命名空间包,
作为来自该组织的其他包的容器。例如,如果来自 Acme 的某人想要向这个命名空间贡献一个
与 SQL 相关的库,那么他可以创建一个在 acme 中注册自己的新的 acme.sql 包。
知道普通包和命名空间包的区别以及它们能够解决的问题是很重要的。一般来说(不
用命名空间包),你将会创建一个 acme 包和一个 sql 子包/子模块,其文件结构如下所示:
$ tree acme/
acme/
├── acme
│ ├── __init __.py
│ └── sql
│ └── __init __.py
└── setup.py
2 directories, 3 files
如果你想添加一个新的子包 — 例如 templating,就会被迫将其包含在 acme 的源
代码树中,如下所示:
$ tree acme/
acme/
├── acme
│ ├── __init __.py
│ ├── sql
│ │ └── __init __.py
│ └── templating
│ └── __init __.py
└── setup.py
3 directories, 4 files
利用这种方法几乎不可能单独开发 acme.sql 和 acme.templating。setup.py
脚本还必须指定每个子包的所有依赖,所以不可能(至少非常困难)选择性地安装 acme
的部分组件。此外,如果有些子包的需求文件有冲突,那么这是一个无法解决的问题。
利用命名空间包,你可以单独保存每个子包的源代码树,如下所示:
$ tree acme.sql/
acme.sql/
├── acme
│ └── sql
│ └── __init __.py
└── setup.py
2 directories, 2 files
$ tree acme.templating/
acme.templating/
├── acme
│ └── templating
│ └── __init __.py
└── setup.py
2 directories, 2 files
你还可以在 PyPI 或者你使用的任何包索引中单独注册它们。用户可以从 acme 命名空
间中选择想要安装的子包,但他们永远不用安装通用的的 acme 包(它并不存在),代码如下:
$ pip install acme.sql acme.templating
注意,独立的源代码树不足以在 Python 中创建命名空间包。如果你不想让你的包互相
覆盖,那么需要做一点额外的工作。此外,正确的处理方式可能会随着你指定的 Python 语
言版本的不同而有所不同。接下来的两节将会详细介绍这方面的详细内容。

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值