一、使用Python设置文件的访问和修改时间
python
import os
import time
# 获取当前时间
now = time.time()
# 设置文件的访问和修改时间
os.utime('test.txt', (now, now))
os.utime(path, (time1,time2)) 参数解析
path:表示文件路径
time1:表示访问时间,单位是秒
time2:表示修改时间,单位是秒
二、使用Python更改Windows系统的文件权限,使所有用户都可以读取和写入该文件
python
import os
import sys
import time
# 更改文件权限,使所有用户都可以读取和写入该文件
if sys.platform == 'win32':
# Windows系统
import win32security
import ntsecuritycon as con
# 获取"Everyone"用户的SID(安全标识符)
userx, domain, type = win32security.LookupAccountName("", "Everyone")
# 获取文件的安全描述符
sd = win32security.GetFileSecurity('test.txt', win32security.DACL_SECURITY_INFORMATION)
# 获取文件的DACL(离散访问控制列表)
dacl = sd.GetSecurityDescriptorDacl()
# 为DACL添加一个ACE(访问控制项),允许"Everyone"用户读取和写入文件
dacl.AddAccessAllowedAce(win32security.ACL_REVISION, con.FILE_GENERIC_READ | con.FILE_GENERIC_WRITE, userx)
# 更新文件的安全描述符
sd.SetSecurityDescriptorDacl(1, dacl, 0)
win32security.SetFileSecurity('test.txt', win32security.DACL_SECURITY_INFORMATION, sd)
参数详解:
1、sys.platform
1. win32:Windows系统
2. darwin:macOS系统
3. linux:Linux系统
4. cygwin:表示Cygwin环境(在Windows系统上运行的Linux模拟环境)
5. freebsd:FreeBSD系统
2、win32security.LookupAccountName(system_name, account_name)
该函数用于获取指定账户的名称、域和SID(安全标识符)。参数含义如下:
(1) system_name:指定要查找账户的系统名称(可以是空字符串,表示本地系统)。
(2) account_name:指定要查找的账户名称。此函数返回一个包含三个元素的元组,分别表示账户的SID、域和类型。
3、win32security.GetFileSecurity(filename, requested_information)
该数用于获取指定文件或目录的安全描述符。参数含义如下:
(1) filename:指定要获取安全描述符的文件或目录的路径。
(2) requested_information:指定要获取的安全描述符信息(可以是多个标志的组合,例如win32security.OWNER_SECURITY_INFORMATION、 | win32security.GROUP_SECURITY_INFORMATION)。
该函数返回一个安全描述符对象。
4、GetSecurityDescriptorDacl()
该方法用于获取安全描述符对象中的DACL(离散访问控制列表)。它不接受任何参数。该方法返回一个DACL对象。
5、AddAccessAllowedAce(revision, access_mask, sid)
该方法用于向DACL对象中添加一个允许访问控制项(ACE)。参数含义如下:
(1) revision:指定DACL的版本号。
(2) access_mask:指定ACE允许的访问权限。
(3) sid:指定ACE应用于哪个用户或组。此方法没有返回值。
6、SetSecurityDescriptorDacl(dacl_present, dacl, dacl_defaulted)
该方法用于设置安全描述符对象中的DACL。参数含义如下:
(1) dacl_present:指定是否存在DACL。
(2) dacl:指定新的DACL对象。
(3) dacl_defaulted:指定DACL是否为默认值。此方法没有返回值。
7、win32security.SetFileSecurity(filename, security_information, security_descriptor)
该函数用于设置指定文件或目录的安全描述符。参数含义如下:
(1) filename:指定要设置安全描述符的文件或目录的路径。
(2) security_information:指定要设置哪些安全描述符信息(可以是多个标志的组合)。
(3) security_descriptor:指定新的安全描述符对象。此函数没有返回值。
三、使用Python更改linux系统的文件权限,使所有用户都可以读取和写入该文件
python
import os
import sys
# 更改文件权限,使所有用户都可以读取和写入该文件
if sys.platform == "linux" or sys.platform == "darwin" or sys.platform == "cygwin":
# macOS、Linux等
# 修改所有人文件权限:可读(4)+ 可写(2)+ 可执行(1)= 7
os.chmod('test1.txt', 0o777)
# 修改文件所属的用户和用户组
os.chown('test.txt', 252, -1)
一、os.chmod(path, mode)
path:要修改权限的文件路径。
mode:用于设置权限的数字。
在类 Unix 系统中,文件权限由三部分组成:所有者、用户组和其他用户 。每一部分都包含读取、写入和执行权限,它们的数字表示分别是:
读取权限:4
写入权限:2
执行权限:1
2、os.chown(path, uid,gid)
需要用root权限执行,sudo python xxxxx.py 可以修改文件所属的用户和用户组