的讨论
在我维护的(遗留(代码中,人们正在使用WindowsError
。我可以继续用OSError
替换所有出现的情况,但遗憾的是,只在三种情况下使用了winerror
属性,即123:
try:
mtime = int(os.path.getmtime(self._s))
except WindowsError, werr:
if werr.winerror != 123: raise
deprint(u'Unable to determine modified time of %s - probably a unicode error' % self._s)
740:
try:
popen = subprocess.Popen(args, close_fds=bolt.close_fds)
if wait: popen.wait()
except UnicodeError:
self._showUnicodeError()
except WindowsError as werr:
if werr.winerror != 740:
self.ShowError(werr)
和32:
try:
patchName.untemp() # calls shutil.move() and os.remove()
except WindowsError, werr:
while werr.winerror == 32 and self._retry(patchName.temp.s,
patchName.s):
try:
patchName.untemp()
except WindowsError, werr:
continue
break
else:
raise
我将如何将这些代码翻译成OSError
?
我在python 2.7中,所以我不能使用pep-3151 中引入的漂亮异常
以下是关于将winerror映射到errno模块
事实证明winerror和errno属性有不同的值——在良好的代码实践中,我没有使用幻数,而是使用errno模块中的常量。So 32:
- except WindowsError as werr:
- if werr.winerror == 32:
+ except OSError as werr:
+ if werr.errno == errno.EACCES: # 13
对于123(另请参阅(:
with open('file', 'w'): pass
newFileName = 'illegal characters: /\:*?"<>|'
try:
os.rename('file', newFileName)
except OSError as e: # winerror = 123, errno = 22
print e
所以CCD_ 5。
740是windows特定的代码,所以我独自离开了。