这是代码:
def make_dir(dir_name):
if os.path.exists(dir_name):
shutil.rmtree(dir_name)
try:
os.makedirs(dir_name)
except OSError, e:
print "ErrorNo: %s (%s)" % (e.errno, errno.errorcode[e.errno])
raise
如果目录已经存在,我得到以下信息:
ErrorNo: 13 (EACCES)
Traceback (most recent call last):
File "run_pnoise.py", line 167, in <module>
make_dir("prep_dat")
File "run_pnoise.py", line 88, in make_dir
os.makedirs(dir_name)
File "c:\Program Files (x86)\Python27\lib\os.py", line 157, in makedirs
mkdir(name, mode)
WindowsError: [Error 5] Access is denied: 'prep_dat'
如果我再次运行该程序,它就可以工作,表明该程序确实可以访问目录,因为shutil.rmtree 调用显然可以正常工作。我想出了一个解决方法,我将发布。但是,是否有更好的解释和/或解决方法?
我的假设是,在操作系统完全删除所有文件和子目录之前,shutil.rmtree 调用正在返回。此外,由于shutil.rmtree 调用不会引发异常,因此makedirs 调用中的任何EACCESS (13) 错误都可能是假的。我的尝试(在 Apalala 的评论后修改):
def make_dir(dir_name):
retry = True
if os.path.exists(dir_name):
shutil.rmtree(dir_name)
while retry:
try:
# per Apalala, sleeping before the makedirs() eliminates the exception!
time.sleep(0.001)
os.makedirs(dir_name)
except OSError, e:
#time.sleep(0.001) # moved to before the makedirs() call
#print "ErrorNo: %s (%s)" % (e.errno, errno.errorcode[e.errno])
if e.errno != 13: # eaccess
raise
else:
retry = False
这似乎可靠地工作。其他帖子中提到了竞争条件问题,但这似乎不太可能,并且可能会导致不同的异常。
最佳答案
我遇到了同样的问题,这看起来与我的解决方案相似,只是我在 sleep (0.1)。
关于python - 在 Windows 上使用 Python 的虚假 OSError, 13 (EACCES) 有什么好的解决方案,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/4609572/