Windows 10中使用Python

时间:2017-08-11 19:17:35

标签: python winapi windows-10 file-permissions

问题:如何使用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)

但它似乎不起作用。另外,我不明白我在使用模块win32securityntsecuritycon做什么。也许有人可以给出一个简单的解释。

编辑:好的,所以我看了一下东西。这是引发的异常:

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
  • 用户帐户名为“admin”,属于“管理员”组。
  • “admin”是所有者,并且根据MSD_DataTHG126.Dsample_info.xml和python脚本的“高级安全设置”具有“完全控制权”。
  • 我还尝试使用“以管理员身份运行”通过CLI运行脚本。发生同样的错误。

我查看了文件夹中的所有文件,发现只有sample_info.xml有RA属性,而所有其他只有A,所以我添加了

path2 = r"D:\\MSD_data\\"+run+r"\\AcqData\\sample_info.xml"
subprocess.check_call(["attrib", "-r", path2, "/S", "/D"])

到脚本,它似乎现在工作。我需要稍等一下,让其他软件生成新文件夹,看看脚本现在是否正常工作。

1 个答案:

答案 0 :(得分:1)

问题似乎是文件具有属性“RA”,这意味着“只读”和“存档”。即使使用的用户帐户是所有文件和文件夹的所有者,shutil.move()在复制到目标位置后尝试删除文件时也会失败。

此问题的解决方法是使用

subprocess.check_call(["attrib", "-r", path])

删除只读文件属性。这解决了我的问题。如果您仍然遇到shutil.move()问题,也可以尝试this solution