Python中os.chmod()需用0o755等八进制字面量而非755,Windows仅支持S_IWRITE/S_IREAD,st_mode需用stat.filemode()或st_mode & 0o777解析。

Python中用os.chmod()修改文件权限的常见错误
直接传入八进制数字(如755)会出错,因为Python默认按十进制解析——755实际等价于八进制1363,完全不是预期的0o755。
- 必须显式写成八进制字面量:
0o755(注意前缀0o,不是0或0x) - 也可用
stat模块的符号常量组合,更安全:stat.S_IRWXU | stat.S_IRGRP | stat.S_IXGRP | stat.S_IROTH | stat.S_IXOTH - Windows下
os.chmod()仅支持stat.S_IWRITE和stat.S_IREAD,其他位被忽略,不要指望它能模拟Linux权限
用os.stat()读取权限时,为什么st_mode看起来像一串大数字?
st_mode是整型掩码,包含文件类型(如目录、普通文件)和权限位,不能直接当八进制数打印。直接print(stat.st_mode)输出的是十进制整数(如33188),毫无可读性。
- 用
stat.filemode(st_mode)转成字符串,例如'-rw-r--r--' - 提取纯权限部分:用位与操作
st_mode & 0o777,再用oct()转成八进制字符串(如oct(33188 & 0o777) → '0o644') - 检查某类权限是否存在:用
st_mode & stat.S_IXUSR判断用户是否可执行,非零即存在
chmod在不同平台的行为差异和兼容性陷阱
Linux/macOS支持完整POSIX权限,而Windows只保留“只读”标志,其余位被丢弃。这意味着跨平台脚本若依赖组/其他用户的写权限控制,会在Windows上静默失效。
- 不要在Windows上测试
os.chmod(path, 0o777)是否真能让所有人写入——它只会移除只读属性,不改变ACL - 需跨平台时,优先用
pathlib.Path.chmod()(Python 3.4+),语义一致且API更简洁,但底层行为仍受限于OS - 若需精细控制Windows ACL(如指定用户权限),必须调用
win32security或subprocess调用icacls,os.chmod()无能为力
import os import stat安全设置权限:用户读写执行,组和其他人读+执行
os.chmod('script.py', 0o755)
立即学习“Python免费学习笔记(深入)”;
安全读取并验证
st = os.stat('script.py') print(stat.filemode(st.st_mode)) # '-rwxr-xr-x' if st.st_mode & stat.S_IXUSR: print("用户有执行权限")
权限位含义和平台限制是硬约束,不是配置问题。改权限前先确认目标系统是否真的支持你要设的那些位。










