我想要这样的行为:
with A() as f:
for x in f:
do_something(f)
这是正确的方法吗?
class A:
def __enter__(self):
print "Entering context"
def __iter__(self):
for x in ["some","list"]:
yield x
def __exit__(self):
print "Deleting context"
答案 0 :(得分:6)
您的contextmanager.__enter__
方法需要返回iterable。它可以为self
:
def __enter__(self):
print "Entering context"
return self
请参阅With Statement Context Managers documentation:
object.__enter__(self)
输入与此对象相关的运行时上下文。
with
语句将此方法的返回值绑定到语句的as
子句中指定的目标(如果有)。
所以无论方法返回什么,然后绑定到作为as
目标给出的名称。
如果提出异常,您的contextmanager.__exit__
method需要能够接受该异常:
def __exit__(self, exc_type, exc_value, traceback):
当没有异常时,with
语句会给你三个None
个参数。