这是代码:

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/

10-13 07:29