4. 特殊路径操作
用户主目录
· 获取当前用户的主目录路径超级常用:
from pathlib import Path
home_dir = Path.home() # 返回当前用户主目录的 Path 对象
print(home_dir) # 输出类似: C:UsersYourUsername (Windows)
临时目录
· 系统有一个用于存放临时文件的默认目录:
import tempfile
from pathlib import Path
# 获取系统临时目录路径
system_temp_dir = Path(tempfile.gettempdir()) # 返回 Path 对象
print(system_temp_dir) # 输出类似: C:Users…AppDataLocalTemp (Windows)
# 生成一个唯一的临时文件路径 (注意: 这个函数只生成路径名,不创建文件!)
temp_file_path = Path(tempfile.mktemp(suffix=”.log”)) # 返回 Path 对象
print(temp_file_path) # 输出类似: /tmp/tmp9k7e5x8v.log (每次运行不同)
# 常用于: with open(temp_file_path, ‘w’) as f: … 来创建和使用临时文件

5. 路径遍历与文件查找
Path 对象提供了遍历目录和查找文件的方法。
列出目录内容 (iterdir())
· 列出指定目录下的直接子项(文件和子目录):
docs_dir = Path(“/home/user/documents”)
print(“Documents 目录下的内容:”)
for item in docs_dir.iterdir(): # 遍历目录下的每个条目
print(f” – {item.name}”) # 打印条目名称
# item 是 Path 对象,可以是文件或目录
递归查找文件 (rglob())
· 在指定目录及其所有子目录中递归搜索匹配特定模式的文件:
docs_dir = Path(“/home/user/documents”)
print(“找到的所有 .txt 文件 (递归搜索):”)
for txt_file in docs_dir.rglob(“*.txt”): # 使用通配符模式
print(txt_file) # 打印找到的每个 .txt 文件的完整路径 (Path对象)
查找特定文件 (glob())
· 在指定目录下(非递归,只在当前目录)搜索匹配特定模式的文件:
docs_dir = Path(“/home/user/documents”)
# 查找当前目录下以 ‘report_’ 开头,以 ‘.txt’ 结尾的文件
# next(…, None) 表明取第一个找到的,如果没找到则返回 None
specific_report = next(docs_dir.glob(“report_*.txt”), None)
if specific_report:
print(f”找到报告文件: {specific_report}”)
else:
print(“未找到匹配的报告文件。”)

注意事项:
1. 优先使用 pathlib:
o 它提供面向对象的接口,更符合 Python 风格。
o 自动处理跨平台路径分隔符 (/ vs )。
o 方法链式调用 (path.parent / ‘subdir’ / ‘file.txt’.exists()) 使代码更简洁。
2. 绝对避免硬编码路径分隔符:
#不推荐 – 硬编码分隔符,不跨平台且易出错
bad_path = “data” + “\” + “input” + “\” + “file.csv”
#推荐 – 使用 Path 和 / 操作符
good_path = Path(“data”) / “input” / “file.csv” # 跨平台安全!
print(good_path)
3. 正确处理用户输入路径:
· 用户输入可能包含 ~(代表主目录)或相对路径。使用 .expanduser() 处理 ~,使用 .resolve() 或 .absolute() 获取明确路径。
user_input = input(“请输入文件或目录路径: “)
# 处理 ~ 并解析为绝对路径
resolved_path = Path(user_input).expanduser().resolve()
print(f”解析后的路径是: {resolved_path}”)
4. 理解 resolve():
o resolve() 不仅规范化路径(消除 ., ..),还会解析路径中所有的符号链接(Symbolic Links) 到它们指向的实际目标路径。当你需要获取文件或目录的“物理”位置时超级有用。.absolute() 只转换绝对路径但不解析符号链接。
5. 安全处理文件操作(如删除):
o 文件操作(删除、移动等)可能因文件不存在、无权限等缘由失败。务必使用 try…except 捕获潜在异常,使程序更健壮。
file_to_delete = Path(“old_backup.zip”)
try:
file_to_delete.unlink() # 删除文件 (Path.unlink())
# 如果是空目录,可以用 Path.rmdir()
# 删除非空目录及内容,可用 shutil.rmtree() (需 import shutil)
print(f”成功删除 {file_to_delete}”)
except FileNotFoundError:
print(f”错误: 文件 {file_to_delete} 不存在,无法删除。”)
except PermissionError:
print(f”错误: 没有权限删除 {file_to_delete}。”)
# 可以捕获其他可能异常,如 IsADirectoryError (如果误对目录用unlink)

总结对比:os.path vs pathlib.Path
常见路径操作在传统 os.path 模块和现代 pathlib.Path 类中的实现方式。pathlib 的 API 一般更直观、更面向对象。
|
操作 (Operation) |
os.path (传统方式) |
pathlib.Path (推荐方式) |
说明 |
|
路径拼接 (Join) |
os.path.join(a, b, c) |
Path(a) / b / c |
/ 操作符简洁直观且跨平台安全。 |
|
获取父目录 (Parent) |
os.path.dirname(p) |
p.parent |
p.parent 返回的是 Path 对象。 |
|
获取文件名 (Name) |
os.path.basename(p) |
p.name |
包含后缀的文件名。 |
|
获取后缀 (Suffix) |
os.path.splitext(p)[1] |
p.suffix |
获取文件扩展名 (如 .txt)。 |
|
检查存在 (Exists) |
os.path.exists(p) |
p.exists() |
检查路径是否存在(文件或目录)。 |
|
是否为文件 (Is File) |
os.path.isfile(p) |
p.is_file() |
检查路径是否存在且是一个普通文件。 |
|
是否为目录 (Is Dir) |
os.path.isdir(p) |
p.is_dir() |
检查路径是否存在且是一个目录。 |
|
绝对路径 (Absolute) |
os.path.abspath(p) |
p.absolute() |
获取基于当前工作目录的绝对路径 (Path对象)。 |
|
规范化路径 (Normalize) |
os.path.normpath(p) |
p.resolve() |
resolve() 更强劲:转换为绝对路径、解析符号链接、消除 . 和 ..。 |



















暂无评论内容