
在 Python 中判断文件是否具有可读、可写或可执行权限,可以使用 os.access() 函数。这个函数结合特定的模式参数,能直接检查当前用户对指定路径的访问权限。
1. 使用 os.access() 检查文件权限
os.access(path, mode) 接受两个参数:文件路径和访问模式。常用模式包括:
- os.R_OK:检查文件是否可读
- os.W_OK:检查文件是否可写
- os.X_OK:检查文件是否可执行
- os.F_OK:检查文件是否存在
示例代码:
import osfile_path = 'example.txt'
立即学习“Python免费学习笔记(深入)”;
if os.access(file_path, os.R_OK): print("文件可读") else: print("文件不可读")
if os.access(file_path, os.W_OK): print("文件可写") else: print("文件不可写")
if os.access(file_path, os.X_OK): print("文件可执行") else: print("文件不可执行")
2. 同时检查多个权限
你可以一次性判断多个权限状态,避免重复调用。
Difeye是一款超轻量级PHP框架,主要特点有: Difeye是一款超轻量级PHP框架,主要特点有: ◆数据库连接做自动主从读写分离配置,适合单机和分布式站点部署; ◆支持Smarty模板机制,可灵活配置第三方缓存组件; ◆完全分离页面和动作,仿C#页面加载自动执行Page_Load入口函数; ◆支持mysql,mongodb等第三方数据库模块,支持读写分离,分布式部署; ◆增加后台管理开发示例
import osdef check_permissions(file_path): if not os.path.exists(file_path): print("文件不存在") return
readable = os.access(file_path, os.R_OK) writable = os.access(file_path, os.W_OK) executable = os.access(file_path, os.X_OK) print(f"可读: {readable}") print(f"可写: {writable}") print(f"可执行: {executable}")调用
check_permissions('example.txt')
3. 注意事项
os.access() 检查的是实际用户的权限(real user ID),而不是有效用户 ID(effective UID),这在涉及 setuid 程序时可能有差异。一般脚本中影响不大。
确保传入的路径是字符串或路径对象,且尽量使用绝对路径以避免因当前工作目录不同导致误判。
该方法不会抛出异常,即使文件不存在也只会返回 False,因此建议先确认文件存在或结合 try-except 处理异常情况。
基本上就这些。用 os.access 配合 R_OK、W_OK、X_OK 就能准确判断文件权限状态。









