python装饰器

装饰器示例代码

def 外func(被装饰func):
    """
    这是一个装饰器示例,展示如何使用中文命名函数和变量。
    被装饰func: 这是将被装饰的函数
    """
    def 内func(*args, **kwargs):
        """
        内func 的 Docstring
        :param args: 一个星号 * 收集位置参数
        :param kwargs: 两个星号 ** 收集关键字参数
        """
        print("开始装饰器功能")
        result = 被装饰func(*args, **kwargs)
        print("结束装饰器功能")
        return result
    return 内func

装饰器应用示例


def outer_func(func):
    def inner_func(*args, **kwargs):
        print("内函数执行前代码")
        result = func(*args, **kwargs)
        print("内函数执行后代码")
        return result
    return inner_func

@outer_func
def send_email(邮箱地址, 主题, 邮件内容):
    print(f"Sending email to: {邮箱地址}")
    print(f"Subject: {主题}")
    print(f"Body: {邮件内容}")  

if __name__ == "__main__":
    send_email("test@test.com", "测试主题", "测试邮件内容.")

在这里插入图片描述


实战应用示例

  • 背景描述:
  1. 数据库在内网,只有跳板机才能连接到;
  2. ecs_client不能直接连接到数据库;
  3. ecs_client能连接到跳板机。
    在这里插入图片描述
def ssh_D(exec_select_sql_func):
    """
    用来在SSH隧道中执行SELECT SQL语句的装饰器
    exec_select_sql_func: 查询sql的函数
    """
    def wrapper(*args, **kwargs):
        """
        wrapper 的 Docstring
        :param args: 一个星号 * 收集位置参数
        :param kwargs: 两个星号 ** 收集关键字参数
        """
        print("1. 建立SSH隧道连接,并建立动态端口转发")
        print("2. 切换全局socket到SSH隧道的动态端口")
        result = exec_select_sql_func(*args, **kwargs)
        print("4. 关闭SSH隧道连接")
        return result
    return wrapper

@ssh_D
def execute_select_sql(sql_query):
    """
    执行SELECT SQL语句的函数
    sql_query: 要执行的SQL查询语句
    """
    print(f"3. 内函数 执行SQL查询: {sql_query}")
    # 模拟查询结果
    return ["结果1", "结果2", "结果3"]  

if __name__ == "__main__":
    sql = "SELECT * FROM users WHERE age > 30;"
    results = execute_select_sql(sql)
    print("查询结果:", results)

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

教Linux的李老师

赞赏是第一生产力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值