[英]try yield finally - did we raise an exception?
是否有可能在finally子句中找出是否有未完成的未被捕获的异常?
我想迭代项目来对它们进行一些相对昂贵的处理,这可能会破坏并引发异常。 所以我想保存我的位置。 但是保存状态也相当昂贵 - 所以我宁愿不是每次都这样做, 就在我屈服的代码中存在异常时 。
我想象的东西模糊地像:
def get_things(my_iterator):
for items in my_iterator:
try:
yield item
finally:
if something_went_wrong(): # magic oracle function for failure
save_state(item)
continue_normal_processing()
但我不知道这是否可能。 值得注意的是, except Exception:
不会引发任何事情,因为异常不在此函数中。
...似乎我对except
行为完全错了。
def f():
for i in range(10):
try:
yield i
except Exception:
print "Nope, this broke"
raise
for x in f():
print x
if x == 2:
raise IndexError
回报
0
1
2
Nope, this broke
Traceback (most recent call last):
...
IndexError
这应该与您想要的类似:
class CatchingExceptionsIterator:
def __init__(self, generator):
self.generator = generator
self.error = None
def __enter__(self):
return self
def next(self):
if self.error is None:
return next(self.generator)
else:
error = self.error
self.error = None
return self.generator.throw(*error)
__next__ = next
def __exit__(self, ty, err, tb):
if ty is not None:
self.error = ty, err, tb
return True
def __iter__(self):
return self
def f():
for i in range(10):
try:
print("yield")
yield i
print("returnFomYield")
except:
import traceback
traceback.print_exc()
c = CatchingExceptionsIterator(f())
for i in c:
with c:
print(i)
if i == 5:
nameerror
必须调整它以适合确切的用例。
输出是:
yield
0
returnFomYield
yield
1
returnFomYield
yield
2
returnFomYield
yield
3
returnFomYield
yield
4
returnFomYield
yield
5
Traceback (most recent call last):
File "withiteration.py", line 27, in f
yield i
File "withiteration.py", line 39, in <module>
nameerror
NameError: name 'nameerror' is not defined
yield
6
returnFomYield
yield
7
returnFomYield
yield
8
returnFomYield
yield
9
returnFomYield
还将执行另外的finally子句。
是否有可能在finally子句中找出是否有未完成的未被捕获的异常?
为什么? 你可以使用except
。 更详细地解释这一点。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.