Python跨平台文件操作应使用pathlib.Path处理路径、内置open()读写文件、shutil执行复制移动删除——避免硬编码分隔符、系统命令及低层接口。
Python 的文件系统操作本身不跨平台,但通过标准库的抽象层(主要是 os、pathlib 和 shutil)可以写出真正跨平台的代码——关键在于避开硬编码路径分隔符、绕过系统特有命令,并统一用高层接口处理路径与文件操作。
pathlib 替代字符串拼接路径手动用 "a/b/c" 或 "a\\b\\c" 写路径会直接导致 Windows/Linux/macOS 兼容问题。正确做法是使用 pathlib.Path,它自动适配底层系统的路径规则:
from pathlib import Path; p = Path("data") / "logs" / "app.log" —— 斜杠 / 是重载运算符,不是字符串除法,p 在 Windows 上生成 data\logs\app.log,在 Linux/macOS 上生成 data/logs/app.log
os.path.join("data", "logs", "app.lo
g") 虽然也能跨平台,但语法冗长;更危险的是 "data/logs/app.log" 这类硬编码字符串,在 Windows 上可能无法识别Path 方法做存在性与类型判断不要依赖 os.sep 或 os.altsep 去解析路径,也不要调用 os.system("ls") 或 subprocess.run(["dir"]) 这类系统命令。所有基础判断应走 Path 实例方法:
p.exists() 判断路径是否存在(文件或目录均可)p.is_file()、p.is_dir()、p.is_symlink() 明确区分类型p.parent 获取父目录,p.name 取文件名,p.suffix 取扩展名 —— 全部自动处理不同系统的路径格式open() + Path,不用 os.open()
os.open() 是低层 POSIX 接口,Windows 支持有限且行为不一致;而内置 open() 经过 Python 运行时封装,已屏蔽平台差异:
Path("config.json").read_text(encoding="utf-8") 或 with Path("output.txt").open("w", encoding="utf-8") as f: f.write("ok")
os.open("file.txt", os.O_RDWR) —— 容易在 Windows 报错,且需手动管理文件描述符shutil,别调系统命令shutil.copy()、shutil.move()、shutil.rmtree() 等函数内部已做平台适配,比 subprocess.run(["cp", ...]) 或 os.system("del") 可靠得多:
shutil.copy(src, dst) 自动处理权限、符号链接、跨文件系统等细节shutil.rmtree(Path("temp")) 安全删除整个目录树,Windows 下也能清理只读文件(onerror 可定制错误处理)shutil.copytree(..., ignore=shutil.ignore_patterns("*.tmp"))