判断路径是否在当前工作目录子目录内需先规范化再前缀匹配:用Path.resolve()获取绝对物理路径,再用is_relative_to()(Py3.9+)或手动加路径分隔符前缀判断,注意大小写、符号链接及根路径等边界情况。
判断一个路径是否在当前工作目录的子目录内,核心是做**路径规范化 + 前缀匹配**。不能只靠字符串包含(比如 str.startswith()),因为路径可能含 ..、符号链接、大小写差异或不同分隔符等问题。
把当前工作目录和目标路径都转成**绝对路径**,并用 os.path.abspath() 或 pathlib.Path.resolve() 消除 .、.. 和符号链接,确保路径真实、可比。
pathlib.Path:cwd = Path.cwd().resolve()target = Path("/some/path").resolve()
.resolve() 会尝试访问文件系统(若路径不存在可能报错),如需容忍不存在路径,可用 .resolve(strict=False)(Python 3.6+)规范化后,只需判断目标路径是否以当前工作目录路径为前缀,且紧接着是一个路径分隔符(避免 /a 匹配到 /ab/c 这类误判)。
target.is_relative_to(cwd)(Python 3.9+)最简洁:if target.is_relative_to(cwd): ✅str(target).startswith(str(cwd) + os.sep) 或str(target.parent) == str(cwd)(仅限直接子目录)——不推荐,太局限
以下情况容易出错,需特别处理:
.resolve() 会跟随符号链接,如果业务逻辑要求“逻辑路径”而非“物理路径”,改用 .absolute() 并手动处理 ..
/ 是所有路径的祖先,但通常不认为它是“子目录”。检查时可额外排除 cwd == target(即是否允许自身)判断 /home/user/project/src/main.py 是否在当前目录子树中:
from pathlib import Path
cwd = Path.cwd().resolve()
target = Path("/home/user/project/src/main.py").resolve()
is_subdir =target.is_relative_to(cwd)
返回 True 表示它在当前工作目录的子目录(或就是当前目录)内。