日期:2023年3月3日
作者:Commas
签名:(ง •_•)ง 积跬步以致千里,积小流以成江海……
注释:如果您觉得有所帮助
,帮忙点个赞
,也可以关注我
,我们一起成长;如果有不对的地方,还望各位大佬不吝赐教,谢谢^ - ^
1.01365 = 37.7834;0.99365 = 0.0255
1.02365 = 1377.4083;0.98365 = 0.0006
一、使用os.chmod来设置文件只读属性
我们可以使用 os
模块中的chmod
(全程:change mode)来设置或取消文件的只读属性。
完整语法:
def chmod(path: FileDescriptorOrPath, mode: int,*, dir_fd: int | None = None, follow_symlinks: bool = True) -> None: ...
常见语法:
def chmod(path: FileDescriptorOrPath, mode: int)
path
:需要修改只读属性的文件路径或目录路径;mode
:权限代码,由八进制数字(octat
)组成。如0o444
表示只读的权限,0o666
表示“读写”的权限,0o777
表示读写执行的权限等等。
使用方法:
- 引入
os
模块; - 使用
os.chmod()
方法去设置或取消文件的只读属性; - 将文件路径和权限代码传递
os.chmod()
方法
示例如下:
import os
# set file as read-only
# 4 = read(4)
os.chmod('readonly.txt', 0o444)
# cancel read-only property
# 6 = read(4) + write(2)
os.chmod('readonly.txt', 0o666)
# set file as read-write-execute
# 7 = read(4) + write(2) + execute(1)
os.chmod('readonly.txt', 0o777)
当然,您也可以这样写:
import os,stat
# (1)set file as read-only
# 4 = read(4)
# os.chmod('readonly.txt', 0o444)
os.chmod('readonly.txt', stat.S_IRUSR + stat.S_IRGRP + stat.S_IROTH)
# (2)cancel read-only property
# 6 = read(4) + write(2)
# os.chmod('readonly.txt', 0o666)
os.chmod('readonly.txt', stat.S_IWUSR + stat.S_IRUSR + stat.S_IWGRP + stat.S_IRGRP + stat.S_IWOTH + stat.S_IROTH)
# (3)set file as read-write-execute
# 7 = read(4) + write(2) + execute(1)
# os.chmod('readonly.txt', 0o777)
os.chmod('readonly.txt', stat.S_IXUSR + stat.S_IWUSR + stat.S_IRUSR + stat.S_IXGRP + stat.S_IWGRP + stat.S_IRGRP + stat.S_IXOTH + stat.S_IWOTH + stat.S_IROTH)
# 或
os.chmod('readonly.txt', stat.S_IRWXU + stat.S_IRWXG + stat.S_IRWXO)
# 我们可以打印出来看看
# 0o444
print(oct(stat.S_IRUSR + stat.S_IRGRP + stat.S_IROTH))
# 0o666
print(oct(stat.S_IWUSR + stat.S_IRUSR + stat.S_IWGRP + stat.S_IRGRP + stat.S_IWOTH + stat.S_IROTH))
# 0o777
print(oct(stat.S_IXUSR + stat.S_IWUSR + stat.S_IRUSR + stat.S_IXGRP + stat.S_IWGRP + stat.S_IRGRP + stat.S_IXOTH + stat.S_IWOTH + stat.S_IROTH))
print(oct(stat.S_IRWXU + stat.S_IRWXG + stat.S_IRWXO))
结果输出:
0o444
0o666
0o777
0o777
二、关于权限代码mode的解读
如上图所示,文件调用权限分为三级 :
- 文件所有者(
Owner
/Users
) - 用户组用户(
Group Users
) - 其它用户(
Other Users
)
其中,每级权限代码范围:1~7
。
符号含义:
R
:读,R
ead的缩写,八进制值为4
;W
:写,W
rite的缩写,八进制值为2
;X
:执行,Ex
ecute的缩写,八进制值为1
;
如:0o444
表示只读的权限,0o666
表示“读写”的权限,0o777
表示读写执行的权限等等;
文件所有者(User
)的权限:
权限代码 | 英文名 | 说明 |
---|---|---|
stat.S_IXUSR | Ex ecute User | 拥有者具有执行权限0o100 |
stat.S_IWUSR | W rite User | 拥有者具有写权限0o200 |
stat.S_IRUSR | R ead User | 拥有者具有读权限0o400 |
stat.S_IRWXU | R ead W rite Ex ecute U ser | 拥有者有全部权限(权限掩码)0o700 |
文件用户组(Group
)的权限:
权限代码 | 英文名 | 说明 |
---|---|---|
stat.S_IXGRP | Ex ecute Gr oup | 组用户有执行权限0o010 |
stat.S_IWGRP | W rite Gr oup | 组用户有写权限0o020 |
stat.S_IRGRP | R ead Gr oup | 组用户有读权限0o040 |
stat.S_IRWXG | R ead W rite Ex ecute G roup | 组用户有全部权限(权限掩码)0o070 |
文件其他用户(Other
)的权限:
权限代码 | 英文名 | 说明 |
---|---|---|
stat.S_IXOTH | Ex ecute Oth er | 其他用户有执行权0o001 |
stat.S_IWOTH | W rite Oth er | 其他用户有写权限0o002 |
stat.S_IROTH | R ead Oth er | 其他用户有读权限0o004 |
stat.S_IRWXO | R ead W rite Ex ecute O ther | 其他用户有全部权限(权限掩码)0o007 |
其它:
权限代码 | 说明 |
---|---|
stat.S_ISVTX | 目录里文件目录只有拥有者才可删除更改0o1000 |
stat.S_ISGID | 执行此文件其进程有效组为文件所在组0o2000 |
stat.S_ISUID | 执行此文件其进程有效用户为文件所有者0o4000 |
stat.S_IREAD | windows 下设为只读 |
stat.S_IWRITE | windows 下取消只读 |
我的微信公众号【会飞的小猴子】,等你来关注哦 ^ - ^
参考文章:
1、《Linux chmod命令》
版权声明:本文为博主原创文章,如需转载,请给出:
原文链接:https://blog.csdn.net/qq_35844043/article/details/129292978