最近一直在折腾 Python 项目,通过对几个 Python 项目依赖管理与构建工具的对比,最后选择了 Poetry。它管理依赖,构建与发布包还是简单的多,不需要处理 setup.py, setup.cfg 和 Makefile 文件, 甚至都不需要了解 wheel 是什么就能往 PyPI 发布包了。
可是,别看 Poetry 的官网一直守护着一副小清新的形像,其实照样处处是坑,其中一个就是与相对引用有关的问题。我们来看下什么样的现像,最后的结论就是:在 Python 中避免使用相对路径引用,因为相对路径的上下文经常在变,然后必要时先执行 poetry install
, 甚至把入口代码拉到包外头去。
什么是相对引用与绝对路径引用,比如在一个包 my_package
中有两个模块(Python 文件) app.py 和 utils, app.py 中对 utils 资源的引用可以写成
from utils import md5 # 不确定 utils 是一个包还是一个模块,有点像是隐式相对路径模块引用
from .utils import md5 # 同一目录中的 utils 模块
import .utils
from ..utils import md5 # 上一级目录中的 utils 模块 (如果 utils.py 在与 app.py 上一级目录的话)
from my_package.utils import md5 # 绝对引用,总是从包名开始
注意 from 后面的 .
与 ..
,相对路径引用不能直接 import, 如不能 import .utils.md5