新项目推荐优先使用pathlib,因其面向对象、可读性强、支持链式调用且自动适配系统分隔符;老代码维护需掌握os.path。两者均跨平台,但pathlib更直观安全。
Python里处理文件路径,os.path 和 pathlib 是最常用的两套工具。前者是传统方式,函数式调用;后者是Python 3.4+引入的面向对象方案,更直观、可读性更强。选哪个不绝对,但新项目推荐优先用 pathlib,老代码维护则常需读懂 os.path。
手动用 "dir/ 拼路径容易出错(比如多一个/、少一个/、Windows反斜杠问题)。正确做法是用标准接口自动适配系统分隔符:
" + "file.txt"
os.path.join("dir", "subdir", "file.txt") → 自动用 / 或 \
Path("dir") / "subdir" / "file.txt" → pathlib.Path 支持 / 运算符,简洁自然查文件名、后缀、父目录等,pathlib 直接用属性,os.path 需调函数:
p = Path("/home/user/docs/report.pdf")p.name → "report.pdf",p.stem → "report",p.suffix → ".pdf",p.parent → Path("/home/user/docs")
os.path:os.path.basename(p)、os.path.splitext(p)[0]、os.path.dirname(p) —— 冗长且易忘顺序检查路径是否存在、是否为文件、是否可读,或创建目录、读写文本,pathlib 方法链式调用,逻辑清晰:
p = Path("data/config.json")if p.exists() and p.is_file():content = p.read_text(encoding="utf-8")
Path("logs").mkdir(exist_ok=True) → 自动创建多级目录(parents=True),无需先检查os.path 对应写法需组合多个函数:os.path.isfile(path) and os.access(path, os.R_OK),易漏判、难维护Windows 路径含盘符(C:\)、反斜杠;Linux/macOS 用正斜杠和根目录 /。两者都处理得当,但注意:
Path("C:/a/b") 在 Windows 和 Linux 下都能解析,但只有 Windows 认它为绝对路径;Linux 会当成相对路径 —— 所以跨平台时建议用 Path.cwd() / "relative/path" 或显式构造 Path.home()
os.path.abspath(".') 和 Path(".").resolve() 都能转绝对路径,但 resolve() 默认会检查路径是否存在(不存在抛错),加 missing=True 可绕过pathlib 不是万能,比如某些底层 C 扩展或极老环境可能只认字符串路径,这时可用 str(p) 转换。但日常开发中,用好 Path 对象,路径操作就变得清晰、可靠、少 bug。