问题:如何使用Python脚本更改Windows 10 PC上的文件权限?
我写了一个Python script来获取由专有软件创建的文件夹,并将它们移动到shutil.move()
的网络驱动器。
专有软件似乎创建了默认情况下只读的文件夹。我需要更改这些文件夹的文件权限,以便shutil.move()
在将文件夹复制到网络驱动器后删除它们。
我搜索过SO以发现os.chmod(path, 0o777)
只能在Unix系统上授予访问权限。在Windows上,它修改文件或文件夹的只读属性。 This question似乎产生了一个解决方案,我尝试如下:
import win32security
import ntsecuritycon as con
account = r"admin"
userx, domain, type = win32security.LookupAccountName ("", account)
sd = win32security.GetFileSecurity(path, win32security.DACL_SECURITY_INFORMATION)
dacl = sd.GetSecurityDescriptorDacl() # instead of dacl = win32security.ACL()
dacl.AddAccessAllowedAce(win32security.ACL_REVISION, con.FILE_GENERIC_READ | con.FILE_GENERIC_WRITE, userx)
sd.SetSecurityDescriptorDacl(1, dacl, 0) # may not be necessary
win32security.SetFileSecurity(path, win32security.DACL_SECURITY_INFORMATION, sd)
但它似乎不起作用。另外,我不明白我在使用模块win32security
和ntsecuritycon
做什么。也许有人可以给出一个简单的解释。
编辑:好的,所以我看了一下东西。这是引发的异常:
Traceback (most recent call last):
File "copyscript.py", line 108, in <module>
copyscript()# the loop needs to be called as a function to delete all assigned variables after each loop
File "copyscript.py", line 93, in copyscript
shutil.move(run, str(target_dir2))#move files renamed to user folder
File "C:\Users\admin\AppData\Local\Programs\Python\Python35\lib\shutil.py", line 550, in move
rmtree(src)
File "C:\Users\admin\AppData\Local\Programs\Python\Python35\lib\shutil.py", line 488, in rmtree
return _rmtree_unsafe(path, onerror)
File "C:\Users\admin\AppData\Local\Programs\Python\Python35\lib\shutil.py", line 378, in _rmtree_unsafe
_rmtree_unsafe(fullname, onerror)
File "C:\Users\admin\AppData\Local\Programs\Python\Python35\lib\shutil.py", line 383, in _rmtree_unsafe
onerror(os.unlink, fullname, sys.exc_info())
File "C:\Users\admin\AppData\Local\Programs\Python\Python35\lib\shutil.py", line 381, in _rmtree_unsafe
os.unlink(fullname)
PermissionError: [WinError 5] Access is denied: 'THG126.D\\AcqData\\sample_info.xml'
D:\MSD_Data\THG126.D\AcqData\sample_info.xml
。MSD_Data
,THG126.D
,sample_info.xml
和python脚本的“高级安全设置”具有“完全控制权”。我查看了文件夹中的所有文件,发现只有sample_info.xml
有RA属性,而所有其他只有A,所以我添加了
path2 = r"D:\\MSD_data\\"+run+r"\\AcqData\\sample_info.xml"
subprocess.check_call(["attrib", "-r", path2, "/S", "/D"])
到脚本,它似乎现在工作。我需要稍等一下,让其他软件生成新文件夹,看看脚本现在是否正常工作。
答案 0 :(得分:1)
问题似乎是文件具有属性“RA”,这意味着“只读”和“存档”。即使使用的用户帐户是所有文件和文件夹的所有者,shutil.move()
在复制到目标位置后尝试删除文件时也会失败。
此问题的解决方法是使用
subprocess.check_call(["attrib", "-r", path])
删除只读文件属性。这解决了我的问题。如果您仍然遇到shutil.move()
问题,也可以尝试this solution。