首页 > 编程语言 >深入探讨 Python 中的装饰器和上下文管理器

深入探讨 Python 中的装饰器和上下文管理器

时间:2023-12-04 22:31:39浏览次数:51  
标签:__ 管理器 Python self time return 上下文 def

Python 作为一门灵活而强大的语言,提供了许多高级特性,其中装饰器(Decorators)和上下文管理器(Context Managers)是其中两个非常有用的概念。这两个功能性特性提供了对代码结构和行为进行修改和控制的强大工具。它们允许程序员在不修改源代码的情况下,添加、修改或扩展函数或类的功能,帮助编写更优雅、更干净的代码,同时提高代码的可重用性和可维护性。

装饰器(Decorators)

装饰器是函数的函数,它接受一个函数作为参数,并返回一个新的函数。它们提供了一种简洁的方式来包装或修改函数的行为。通过装饰器,可以在不改变原始函数代码的情况下,添加额外的功能或逻辑,如日志记录、性能计时、权限检查等。这种能力使得装饰器成为Python中函数式编程范式的强大工具之一。

基本语法

def decorator_function(func):
    def wrapper(*args, **kwargs):
        # 添加装饰逻辑
        return func(*args, **kwargs)
    return wrapper

@decorator_function
def some_function():
    # 函数体
    pass

举例说明:

1. 计时器装饰器

import time

def timer(func):
    def wrapper(*args, **kwargs):
        start_time = time.time()
        result = func(*args, **kwargs)
        end_time = time.time()
        print(f"Execution time: {end_time - start_time} seconds")
        return result
    return wrapper

@timer
def some_function():
    time.sleep(2)
    print("Function executed")

some_function()
# 输出:Function executed
#      Execution time: 2.000123 seconds

2. 权限检查装饰器

def check_permission(func):
    def wrapper(*args, **kwargs):
        if user_has_permission():
            return func(*args, **kwargs)
        else:
            raise PermissionError("Permission denied")
    return wrapper

@check_permission
def sensitive_operation():
    print("Operation executed")

sensitive_operation()
# 如果用户有权限,输出:Operation executed
# 如果用户无权限,抛出 PermissionError

上下文管理器(Context Managers)

上下文管理器提供了对资源进行安全获取和释放的机制,即使在出现异常时也能确保资源的释放。这对于处理文件、数据库连接或其他需要资源管理的情况特别有用。上下文管理器可以使用 with 语句来确保在代码块执行前获取资源,在代码块执行后释放资源,保证资源的正确处理。

基本语法

class CustomContextManager:
    def __enter__(self):
        # 分配资源
        return resource
    
    def __exit__(self, exc_type, exc_value, traceback):
        # 释放资源
        pass

with CustomContextManager() as resource:
    # 使用资源的代码块
    pass

举例说明:

3. 文件操作的上下文管理器

class FileManager:
    def __init__(self, filename, mode):
        self.filename = filename
        self.mode = mode
    
    def __enter__(self):
        self.file = open(self.filename, self.mode)
        return self.file
    
    def __exit__(self, exc_type, exc_value, traceback):
        self.file.close()

with FileManager("example.txt", "w") as file:
    file.write("Hello, Context Manager!")
# 文件 example.txt 被正确地写入数据,并在代码块结束时自动关闭

4. 数据库连接的上下文管理器

import sqlite3

class DatabaseConnection:
    def __init__(self, database):
        self.database = database
    
    def __enter__(self):
        self.connection = sqlite3.connect(self.database)
        return self.connection
    
    def __exit__(self, exc_type, exc_value, traceback):
        self.connection.close()

with DatabaseConnection("example.db") as conn:
    cursor = conn.cursor()
    cursor.execute("CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY, name TEXT)")
# 在代码块中成功创建数据库连接,并在结束时自动关闭连接

高阶概念与应用

  • 装饰器链:多个装饰器可以被串联使用,以添加多个功能。
  • 上下文管理器的异步支持async with 语句在异步代码中管理异步资源的获取和释放。

这些高级特性提供了对 Python 代码逻辑和资源管理更细粒度的控制,使得代码更具灵活性和可维护性。

结语

装饰器和上下文管理器是 Python 中强大而灵活的特性,它们可以使代码更简洁、更易于维护,并且提供了许多便利。

标签:__,管理器,Python,self,time,return,上下文,def
From: https://blog.51cto.com/u_16170163/8682186

相关文章

  • python包迁移
    在没有网络的python环境中安装python包(从另一个环境打包转移到另一个环境)1、在有网络的电脑上安装我们需要的包2、在有网络的电脑下执行下面语句pipfreeze>requirements.txt这个时候就会在命令行所在的目录生成一个requirements.txt,这里面列出了有网络电脑的包的名字和版本。......
  • Python中execjs执行JS代码出现中文乱码
    1、乱码场景新建文件code.js,详情如下:functionfun(){return"我是fun函数";}在Python中执行此JS代码:1importexecjs23#读取js4withopen("code.js",encoding="utf8")asf:5jsCode=f.read()6print(jsCode)78#编辑......
  • Python的with open
    1、文件的基本操作1.打开文件2.操作文件3.关闭文件关键字:open方式1f=open(r'a.txt','r',encoding='utf-8')#f=open(r'a.txt',mode='r',encoding='utf-8')res=f.read()print(res)##关闭文件:释放资源的#f.clo......
  • 填补表格文件日期列中缺少的天数并用0填充该行其他数据:Python
      本文介绍基于Python语言,读取一个不同的行表示不同的日期的.csv格式文件,将其中缺失的日期数值加以填补;并用0值对这些缺失日期对应的数据加以填充的方法。  首先,我们明确一下本文的需求。现在有一个.csv格式文件,其第一列表示日期,用2021001这样的格式记录每一天的日期;其后面几......
  • python中级之字符编码
    小引字符编码(CharacterEncoding)是计算机显示文本的基础,是每一位IT从业者必知的计算机基础知识点,如同数值在计算中如何存储表示,那么基础,那么重要。参考笔记字符编码笔记:ASCII,Unicode和UTF-8-阮一峰的网络日志(ruanyifeng.com)各种编码UNICODE、UTF-8、ANSI、ASCII、G......
  • Python 解析JSON实现主机管理
    JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式,它以易于阅读和编写的文本形式表示数据。JSON是一种独立于编程语言的数据格式,因此在不同的编程语言中都有对应的解析器和生成器。JSON格式的设计目标是易于理解、支持复杂数据结构和具有良好的可扩展性。JSON数据是......
  • 【python入门之文件操作】---文件操作
    【一】文本处理引入应用程序运行过程中产生的数据最先都是存放于内存中的若想永久保存下来,必须要保存于硬盘中。应用程序若想操作硬件必须通过操作系统而文件就是操作系统提供给应用程序来操作硬盘的虚拟概念用户或应用程序对文件的操作,就是向操作系统发起调用,然后由操作系统......
  • 【python入门之文字符编码】---字符编码
    简介计算机中储存的信息都是用二进制数表示的;而我们在屏幕上看到的英文、汉字等字符是二进制数转换之后的结果。通俗的说,按照何种规则将字符存储在计算机中,如’a’用什么表示,称为"编码";反之,将存储在计算机中的二进制数解析显示出来,称为"解码",如同密码学中的加密和解密。在解码过......
  • 【python基础之可变和不可变数据类型】---python之栈的介绍
    【二】栈【0】引入https://www.hello-algo.com/chapter_stack_and_queue/栈如同叠猫猫,而队列就像猫猫排队。两者分别代表着先入后出和先入先出的逻辑关系。【1】栈的介绍「栈stack」是一种遵循先入后出的逻辑的线性数据结构。我们可以将栈类比为桌面上的一摞盘......
  • 【python基础之可变和不可变数据类型】--- python之堆的介绍
    【一】堆堆--简介:一种基于树的数据结构堆是满足堆特性的完全二叉树,即树中每个节点的值大于或等于其子节点的值。有两种类型的堆:1.最大堆:在最大堆中,每个节点的值都大于或等于其子节点的值,并且根节点在树中具有最大值。2.最小堆:在最小堆中,每个节点的值都小于或等于其子......