在python中我们经常见到这样的代码:
with open('x.txt') as f:
f.read()
这是关于文件读写的语句,为什么要这么写呢?如果刚学习python我们一般这么写:
f=open('x.txt')
f.read()
f.close()
但是当在读取时出现错误,程序就终止了,文件x.txt还未关闭。这时候我们要引进错误机制:
try:
f=open('x.txt')
f.read()
expert:
pass
finally:
f.close()
无论在读取文件x.txt有没有错误,都会执行finally里的f.close(),都会关闭文件x.txt。但是这样是不是很麻烦呢,代码就显得比较多,因此python就使用with。
with语句的格式如下:
with expression as var:
block
python会将上面的代码翻译如下:
mgr=(expression)
exit=type(mgr).__exit__
value=type(mgr).__enter__(mgr)
exc=True
try:
try:
var=value
block
except:
exc=flase
if not exit(mgr,*sys.exc_info()):
raise
finally:
if exc:
exit(mgr,None,None,None)
上面的代码,先将表达式expression赋值给mgr,并且将mgr的类的enter()赋值给value、exit()赋值给exit,并且设置了一个标志exc=True。无论程序有没有错误都会执行finally里的代码,但是如果程序无错误exc=True,所以执行exit(mgr,None,None,None),如果有错误,先执行exc=Flase,再执行下一句exit(mgr,*sys.exc_info())。