使用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系统的文件权限,使所有用户都可以读取和写入该文件

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系统的文件权限,使所有用户都可以读取和写入该文件

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 可以修改文件所属的用户和用户组

path:路径

uid:新的所有者的用户id

gid:新的组id

  • 24
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

limengshi138392

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值