正常情况下,我们都是使用 pdm init 来初始化项目时,而初始化后,会在本地生成一个 pyproject.toml 文件和 pypackages 目录,这只是 pdm 默认的模式。
为理解方便,pdm 管理的项目,我将其分为两种
实际上,咱在初始化的时候,还可以再加个参数 -g/–global ,它表示该项目将使用全局的 pdm 的 pyproject.toml 配置文件。
若你是首次使用 -g/–global 参数,那么它将创建 ~/.pdm/global-project/ 目录,将在该目录下创建 pyproject.toml
若你是二次使用 -g/–global 参数,那么你输入的信息将覆盖原来的 pyproject.toml 的配置
使用过 -g 后,你再使用 pdm list -g 查看全局已安装的包时,就会发现多了个 global-project 的包?然后在 Location 列有 -e /Users/iswbm/.pdm/global-project 指定全局模式 pyproject.toml 及 pdm.lock 所在的位置
默认情况下,当你没有指定 -g 参数去执行 pdm 命令时,它只会先从本地目录读取 pyproject.toml
而当你指定 -g 命令,不管你本地项目是否为一个 pdm 创建的项目,是否存在 pyproject.toml,pdm 都只会去读取全局的 pyproject.toml
如下所示,我分别在全局和本地的 pyproject.toml 添加不同的 shell 命令,在加 -g 和 不加 -g 的效果就非常明显了
上面之所以说默认情况下如果本地目录没有 pyproject.toml ,pdm 并不会去使用全局的 pyproject.toml。
是因为 pdm 提供了一个开关(auto_global),可以自行改变这种默认的行。
在局部项目下,安装的包是装在了 packages 下,那使用 -g 指定全局环境的包,是装在哪里呢?
尝试在 ~/.pdm 目录下寻找,并没有任何发现
实际上,它是安装在 pdm 工具本身所在虚拟环境中,而不是你机器全局的 Python 环境中。
使用 -g 参数后,你可以在机器的任何位置执行命令,而不加 -g 呢?难道要当前目录下有 pyproject.toml 才可以?
这样岂不是要求你需要处于项目的根目录才可以 pdm 管理局部项目?
经过测试,可以发现 pdm 并不需要你处于项目的根目录,只要你所处的位置的父级目录中有发现 pyproject.toml 一样可以管理局部项目(实际是不是这个逻辑,没有看源代码还不确定)
上面介绍了两种 pdm 的项目:
全局项目:可以在任意位置使用 pdm 去管理全局项目
局部项目:只能在项目根目录或及子目录里使用 pdm 管理项目
而实际使用中,你可能还希望能在任意位置去管理非全局项目,这个需求只要你加 -p/–project 即可实现
那有没有办法使用 a 项目的 pyproject.toml 及 pdm.lock 去管理 b 项目呢?
答案是不行。
pyproject.toml 及 pdm.lock 所在的位置就是 pdm 管理项目的根目录,无法通过 -p 来实现该需求。