0

0

上下文管理器揭秘:简化 Python 中的资源处理

碧海醫心

碧海醫心

发布时间:2024-11-16 10:00:11

|

343人浏览过

|

来源于dev.to

转载

上下文管理器揭秘:简化 python 中的资源处理

简介...

python 中的上下文管理器是一个强大的工具,可让您以安全有效的方式管理资源的设置和拆卸。它们提供了一种方法来确保资源正确初始化、使用和清理,即使面对异常或意外的控制流也是如此。

使用上下文管理器的主要好处是它们可以帮助您编写更健壮、可维护的 python 代码。通过封装资源管理逻辑,上下文管理器可以更轻松地确保资源得到正确处理,从而降低资源泄漏或状态不一致的风险。

常见用例

上下文管理器的一些常见用例包括:

  • 文件处理(例如,open())
  • 数据库连接
  • 锁定机制
  • 临时目录管理
  • 分析和计时代码执行

with 语句

在 python 中使用上下文管理器的主要方法是使用 with 语句。 with 语句提供了使用上下文管理器的便捷语法,使您可以专注于代码的核心逻辑,而不用担心资源管理。

立即学习Python免费学习笔记(深入)”;

以下是使用 with 语句打开文件的示例:

with open('data.txt', 'r') as file:
    content = file.read()
    print(content)

当退出 with 块时,无论是正常退出还是由于异常,都会自动调用上下文管理器的 __exit__() 方法,确保文件正确关闭。

实现自定义上下文管理器

要创建自定义上下文管理器,您需要定义一个具有两个特殊方法的类:__enter__() 和 __exit__()。 __enter__() 方法负责设置资源,而 __exit__() 方法负责清理资源。

以下是管理 postgresql 数据库连接的自定义上下文管理器的示例:

import psycopg2

class postgresmanager:
    def __init__(self, host, port, database, user, password):
        self.host = host
        self.port = port
        self.database = database
        self.user = user
        self.password = password
        self.conn = none

    def __enter__(self):
        self.conn = psycopg2.connect(
            host=self.host,
            port=self.port,
            database=self.database,
            user=self.user,
            password=self.password
        )
        return self.conn

    def __exit__(self, exc_type, exc_value, traceback):
        if self.conn:
            if exc_type is none:
                self.conn.commit()
            else:
                self.conn.rollback()
            self.conn.close()
        return false

在这个例子中,__enter__()方法使用提供的连接参数建立到postgresql数据库的连接,__exit__()方法负责提交或回滚事务,具体取决于是否发生异常,然后关闭连接。

__exit__() 方法接收三个参数:exc_type、exc_value 和traceback,它们提供有关 with 块中发生的任何异常的信息。在本例中,如果发生异常,该方法将回滚事务;否则,它会提交事务。

通过使用此自定义上下文管理器,您可以简化数据库交互并确保连接正确关闭,即使面对异常也是如此:

台讯电子企业网站管理系统  简繁全功能版
台讯电子企业网站管理系统 简繁全功能版

超级适合代理建设企业站点的企业源码,超方面实用!程序说明: 1.特色:简繁中文切换、产品展示系统、新闻发布系统、会员管理系统、留言本计数器、网站信息统计、强大后台操作 功能等; 2.页面包括:首页、企业介绍、滚动公告通知发布系统、企业新闻系统、产品展示系统、企业案例发布展示系 统、企业招聘信息发布系统、信息资源下载系统、在线定单系统、在线客服系统、在线留言本系统、网站调查投票系统、友情连接系统、会

下载
with postgresmanager('localhost', 5432, 'demo_db', 'myuser', 'mypassword') as conn:
    with conn.cursor() as cursor:
        cursor.execute("create table customers (id serial primary key, name text)")
        cursor.execute("insert into customers (name) values (%s)", ('meqdad',))
        # other database operations here...

这种方法通过将数据库连接管理逻辑封装在上下文管理器中,帮助您编写更健壮且可维护的代码。

上下文管理器生成器

除了创建自定义上下文管理器类之外,您还可以使用生成器函数创建上下文管理器。这种方法在某些情况下可以更简洁、更容易阅读。

这是管理锁的上下文管理器生成器的示例:

from contextlib import contextmanager
from threading import Lock

@contextmanager
def lock_manager(lock):
    lock.acquire()
    try:
        yield lock
    finally:
        lock.release()

在此示例中,@contextmanager 装饰器用于定义充当上下文管理器的生成器函数。 yield 语句用于定义控制权转移到 with 块的点,finally 块确保即使发生异常也能释放锁。

标准库中的上下文管理

python 标准库提供了许多内置的上下文管理器,您可以在代码中使用它们。其中包括:

  • open():管理文件的打开和关闭。
  • lock():管理锁的获取和释放。
  • threadpoolexecutor():管理工作线程池的创建和清理。

使用这些内置上下文管理器可以帮助您编写更简洁、更可靠的代码,因为资源管理逻辑已经为您实现。

最佳实践和注意事项

与上下文管理器合作时,需要牢记一些最佳实践和注意事项:

  • 错误处理和清理:确保您的 __exit__() 方法正确处理异常并清理资源,即使面对意外错误也是如此。
  • 嵌套上下文管理器:您可以相互嵌套上下文管理器,这在管理多个资源时非常有用。
  • 性能注意事项:虽然上下文管理器通常很高效,但请注意资源的设置和拆卸所带来的任何开销,尤其是在性能关键的代码中。

最后一句话

上下文管理器是 python 生态系统中的一个强大工具,允许您编写更健壮、可维护的 python 代码。

通过封装资源管理逻辑,上下文管理器帮助您确保资源得到正确处理,降低资源泄漏或状态不一致的风险。

无论您是使用内置上下文管理器还是创建自己的自定义上下文管理器,了解上下文管理器的基础知识都将帮助您编写更清晰、更高效、更可靠的 python 代码。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

503

2023.08.10

postgresql常用命令
postgresql常用命令

postgresql常用命令psql、createdb、dropdb、createuser、dropuser、l、c、dt、d table_name、du、i file_name、e和q等。本专题为大家提供postgresql相关的文章、下载、课程内容,供大家免费下载体验。

158

2023.10.10

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

978

2023.11.02

postgresql常用命令有哪些
postgresql常用命令有哪些

postgresql常用命令psql、createdb、dropdb、createuser、dropuser、l、c、dt、d table_name、du、i file_name、e和q等。更详细的postgresql常用命令,大家可以访问下面的文章。

199

2023.11.16

postgresql常用命令介绍
postgresql常用命令介绍

postgresql常用命令有l、d、d5、di、ds、dv、df、dn、db、dg、dp、c、pset、show search_path、ALTER TABLE、INSERT INTO、UPDATE、DELETE FROM、SELECT等。想了解更多postgresql的相关内容,可以阅读本专题下面的文章。

270

2023.11.20

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

358

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2082

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

349

2023.08.31

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.3万人学习

Django 教程
Django 教程

共28课时 | 3.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号