在我维护的(遗留)代码中,人们正在使用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?
我在python2.7中,所以我不能使用佩普-3151中引入的很好的异常
下面是一个关于将winerror映射到errno模块的讨论
发布于 2016-09-05 20:39:25
winerror和errno属性有不同的值--在良好的代码实践中,我没有使用神奇的数字,而是使用了errno模块中的常量。所以32:
- except WindowsError as werr:
- if werr.winerror == 32:
+ except OSError as werr:
+ if werr.errno == errno.EACCES: # 13123 (另请参阅):
with open('file', 'w'): pass
newFileName = 'illegal characters: /\\:*?"<>|'
try:
os.rename('file', newFileName)
except OSError as e: # winerror = 123, errno = 22
print e所以errno.EINVAL。
740是在windows特定的代码中,所以我单独离开了。
https://stackoverflow.com/questions/39166817
复制相似问题