Python上下文管理器什么时候用,如何用
Admin 2022-08-08 群英技术资讯 1332 次浏览
今天这篇我们来学习和了解“Python上下文管理器什么时候用,如何用”,下文的讲解详细,步骤过程清晰,对大家进一步学习和理解“Python上下文管理器什么时候用,如何用”有一定的帮助。有这方面学习需要的朋友就继续往下看吧!# 创建一个文件写入字符串“Python”
f = open('123.txt', 'w')
f.write("python")
f.close()
# 使用with语句调用上下文实现文件写入操作
with open('123.txt', 'w') as f:
f.write('python')
上下文是 context 直译的叫法,在程序中用来表示代码执行过程中所处的前后环境,比如在文件操作时,文件需要打开关闭,而文件读写操作就处于文件操作的上下文环境中;
上下文管理器,上下文管理器是指在一段代码执行之前,执行一些预处理的工作,代码执行之后再执行一些清理工作。
上下文管理器中有enter()和 exit() 两个方法,enter()方法在执行 with 后面的语句时执行,一般用来处理操作前的内容,比如一些创建对象,初始化等; exit() 方法在 with 内的代码执行完毕后执行,一般用来处理一些善后收尾工作,比如文件的关闭,数据库的关闭等。
资源管理功能,即文件处理、网络连接、数据库连接等操作时需要关闭资源。
也可以在代码执行前后增加功能,类似于装饰器,比如代码之前做权限验证等。
import pymysql
class DBConnection(object):
def __init__(self,ip,user,passwd,db):
self.ip = ip
self.user = user
self.passwd = passwd
self.db = db
def __enter__(self):
self.conn = pymysql.connect(self.ip, user=self.user, passwd=self.passwd, db=self.db)
self.cur = conn.cursor()
return self.cur
def __exit__(self, exc_type, exc_val, exc_tb):
self.cur.close()
self.conn.close()
with DBConnection('192.168.121.xxx', user="xxx", passwd="123456", db="xxx") as cur:
cur.execute("select * from studnet;")
result = cur.fetchall()
print(result)
完成DBConnection这个类,每次连接数据库时,只要简单的调用with语句即可,不需要关心数据库的关闭、异常等
class MyOpen(object):
"""自定义上下文管理类"""
def __init__(self, file, mode):
self._file = file
self._mode = mode
def __enter__(self):
self._handle = open(self._file, self._mode)
return self._handle
def __exit__(self, exc_type, exc_val, exc_tb):
# print('Type: ', exc_type)
# print('Value:', exc_val)
# print('TreacBack:', exc_tb)
self._handle.close()
print("异常已被处理")
return True
# 读的模式打开文件,进行写操作,不支持
with MyOpen('123.txt', 'r') as f:
f.write('python')
#输出:
异常已被处理
with 语法不仅可以简化资源操作的后续清除操作,还可以代替 try/finally 进行异常处理
当with中执行的语句发生异常时,异常信息会被发送到 exit()方法的参数中, exit() 方法有如下三个参数:
这三个参数都与异常有关,with语句会把异常的exc_type ,exc_val 和exc_tb传递给 exit() 方法,它让exit() 方法来处理异常 ,如果exit()返回的是True,那么这个异常就被忽略,并按照我们定义的方式进行抛出。如果exit()返回的是True以外的任何东西,那么这个异常将被with语句抛出。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章给大家分享的是python怎样获取数组元素的下标的方法。下文给大家介绍了三种实现方法,小编觉得挺实用的,因此分享给大家做个参考,感兴趣的朋友接下来一起跟随小编看看吧。
这篇文章主要为大家详细介绍了Python利用Django完整的开发一个博客系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
这篇文章主要介绍了两行代码解决Jupyter Notebook中文不能显示的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
这篇文章主要为大家介绍了python神经网络Batch Normalization底层原理详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
对于开发一个游戏来说,窗口的显示肯定是前提中的前提,对于pygame来说,只需要一小段代码就可以初始化窗口,下面这篇文章主要给大家介绍了关于pygame自定义窗口创建及相关操作的相关资料,需要的朋友可以参考下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008