iis服务器助手广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python的代理类怎么实现
  • 300
分享到

Python的代理类怎么实现

2023-06-29 14:06:07 300人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

这篇“python的代理类怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python的代理类怎么实现”文章吧。代理类

这篇“python的代理类怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python的代理类怎么实现”文章吧。

代理类的一个简单的实现方式示例

目标:实现类Product的实例属性让另一个类Proxy来代理访问和控制,想将对外公布的属性交给代理类让外部访问和控制,不想对外公布的属性无法通过代理来访问和控制,这里不想对外公布的属性约定用下划线命名开头

# proxy_example1.py# 以下是一个代理类实现只读访问的示例# 目标:代理后只能访问和修改Product的公开属性,私有属性_current只能查看不能修改class Product:    def __init__(self, price, quantity):        self.price = price        self.quantity = quantity        self._current = 123# 只暴露代理类Proxy给外部使用class Proxy:    def __init__(self, obj):        self._obj = obj    def __getattr__(self, item):    # 本实例没有找到的属性会执行__getattr__方法        if item.startswith("_"):    # 约定下划线开头的方法不能访问到被代理的类,只会访问到代理类            raise Exception(f"{item} not found")    # Product存在的私有属性也不希望被外部知道        return getattr(self._obj, item)    def __setattr__(self, key, value):        if key.startswith("_"):     # 约定下划线开头的方法不能访问到被代理的类,只会访问到代理类            # 注:这里不能raise,这会导致Proxy的实例都无法创建(__dict__等属性无法创建)            super(Proxy, self).__setattr__(key, value)   # 避免无限循环        else:            setattr(self._obj, key, value)    # 要求只能删除非下划线开头的属性    def __delattr__(self, item):        if item.startswith("_"):            super(Proxy, self).__delattr__(item)    # 避免无限循环        else:            delattr(self._obj, item)def test_getattr():    p = Product(10, 1)    pp = Proxy(p)    print(pp.price)    print(pp._curr)def test_setattr():    p = Product(10, 2)    pp = Proxy(p)    pp.abc = 1    print(pp.abc, p.abc)    pp._curr = 10000    print(pp._curr)  # 私有属性,设置给了代理类    print(p._curr)  # raise an error, 被代理的类Product的属性没有设置成功也无法访问def test_delattr():    p = Product(10, 2)    pp = Proxy(p)    pp.abc = 123    print(pp.abc, p.abc)    # 删除公开属性    del pp.abc  # 成功    # print(pp.abc, p.abc)  # 已被删除    # # 删除私有属性    # del pp._curr    # 会尝试删除Proxy的私有属性,raise AttributeError: _curr    # 先创建在删除    pp._def = 123   # 这个操作只会设置Proxy的实例属性    print(pp._def)      # 访问的是Proxy实例属性,被代理的Product实例没有创建_def属性    # del pp._def     # 删除的是Proxy的实例属性    # print(pp._def)

测试获取属性

if __name__ == '__main__':    test_getattr()

输出:

10
...
Exception: _curr not found
...

测试设置属性

if __name__ == '__main__':    test_delattr()

输出

1 1
10000
...
AttributeError: 'Product' object has no attribute '_curr'
...

测试删除属性

if __name__ == '__main__':    test_delattr()

输出

123 123
123

注:以双下划线开头和结尾的方法无法被代理,想要使用,必须在代理类中定义出这个方法,然后重定向到被代理的类的方法,比如你想使用isinstance()方法就要在Proxy伪造定义__class__属性,想要使用len()方法就要在Proxy重定向返回到被代理的类的len方法

# proxy_example2.pyclass Product:    def __init__(self, price, quantity):        self.price = price        self.quantity = quantity        self._current = 123    def __len__(self):        return 111# 只暴露代理类Proxy给外部使用class Proxy:    def __init__(self, obj):        self._obj = obj    def __getattr__(self, item):    # 本实例没有找到的属性会执行__getattr__方法        if item.startswith("_"):    # 约定下划线开头的方法不能访问到被代理的类,只会访问到代理类            raise Exception(f"{item} not found")    # Product存在的私有属性也不希望被外部知道        return getattr(self._obj, item)    def __setattr__(self, key, value):        if key.startswith("_"):     # 约定下划线开头的方法不能访问到被代理的类,只会访问到代理类            # 注:这里不能raise,这会导致Proxy的实例都无法创建(__dict__等属性无法创建)            super(Proxy, self).__setattr__(key, value)   # 避免无限循环        else:            setattr(self._obj, key, value)    # 要求只能删除非下划线开头的属性    def __delattr__(self, item):        if item.startswith("_"):            super(Proxy, self).__delattr__(item)    # 避免无限循环        else:            delattr(self._obj, item)    @property    def __class__(self):    # 伪造类        return self._obj.__class__    def __len__(self):        return len(self._obj)def test_instance():    p = Product(10, 2)    pp = Proxy(p)    print(pp.__class__)    print(isinstance(pp, Product))      # 如果不伪造__class__,会返回Falsedef test_len():    p = Product(10, 2)    pp = Proxy(p)    print(len(pp))  # 如果Proxy实例不定义__len__方法,会报错TypeError: object of type 'Proxy' has no len()

测试伪造的实例class类型

if __name__ == '__main__':    test_instance()

输出

<class '__main__.Product'>
True

测试获取长度

if __name__ == '__main__':    test_len()

输出

111

一个实现日志输出的代理类的简化示例

捕获WEB server报错日志并执行异常处理的示例

# logger_proxy.py# -*- coding:utf-8 -*-from functools import wrapsclass DAL:    @claSSMethod    def dm1(cls, req, *args):        print("dm1...", f"{req=}")        print(1/0)      # 故意抛出异常        return "dm1"class BLL:    @classmethod    def bm1(cls, req):        print("bm1...", f"{req=}")        return DAL.dm1(req)class Application:    def __init__(self, req):        self.req = req        self._p = "private attr"    def hd1(self):        return BLL.bm1(self.req)class LoggerProxy:    def __init__(self, obj):        self._obj = obj    def __getattr__(self, item):    # LoggerProxy类实例没获取到的属性会执行这个方法        attr = getattr(self._obj, item)        if callable(attr):  # 获取到了方法,则处理异常捕获            @wraps(attr)            def wrapped_method(*args, **kwargs):                # print(f"Before access to attribute/method: {item}")                try:                    method = attr(*args, **kwargs)                except ZeroDivisionError:                    # 捕获异常然后处理...                    raise Exception(f"{attr.__name__} received a zero division error.")                # print(f"After attribute/method {item} returned")                return method            return wrapped_method        else:   # 获取到了属性,直接返回            return attrif __name__ == '__main__':    lp = LoggerProxy(Application("abc"))    print(lp.req)    print(lp._p)    print(lp.hd1())

运行输出

abc
private attr
bm1... req='abc'
dm1... req='abc'
Traceback...
ZeroDivisionError: division by zero
During handling of the above exception, another exception occurred:
Traceback...
Exception: hd1 received a zero division error.

以上就是关于“Python的代理类怎么实现”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网Python频道。

--结束END--

本文标题: Python的代理类怎么实现

本文链接: https://www.lsjlt.com/news/325328.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Python的代理类怎么实现
    这篇“Python的代理类怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python的代理类怎么实现”文章吧。代理类...
    99+
    2023-06-29
  • python中怎么利用class类实现可迭代
    今天就跟大家聊聊有关python中怎么利用class类实现可迭代,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 当定义一个普通的类时,指向类的实例默认情况下是不可迭代的,如下In&n...
    99+
    2023-06-01
  • 使用Python处理KNN分类算法的实现代码
    目录KNN分类算法的介绍测试数据Python代码实现结果分析简介: 我们在这世上,选择什么就成为什么,人生的丰富多彩,得靠自己成就。你此刻的付出,决定了你未来成为什么样的人...
    99+
    2024-04-02
  • python上下文管理器怎么实现类
    本篇内容介绍了“python上下文管理器怎么实现类”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!说明通过定义__enter__和__exit...
    99+
    2023-06-20
  • JDK动态代理,代理接口没有实现类,实现动态代理方式
    目录JDK动态代理,代理接口没有实现类,实现动态代理被代理的接口:代理对象:那么接下来测试一下:jdk动态代理为什么要接口先通过一个简单例子实现功能:编写测试方法:里面的getPro...
    99+
    2024-04-02
  • Python中类的继承怎么实现
    本篇内容主要讲解“Python中类的继承怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python中类的继承怎么实现”吧!1. 单继承继承的主要作用是实现代码的重用。继承使得子类拥有父类...
    99+
    2023-07-02
  • Python迭代器的实现原理
    目录前言:迭代器的创建迭代器的底层结构迭代器是怎么迭代元素的?小结前言: 在Python里面,只要类型对象实现了__iter__,那么它的实例对象就被称为可迭代对象(Iterable...
    99+
    2024-04-02
  • python 实现 代理模式
    本文的目录地址本文的代码地址在某些应用中,我们需要在访问某个对象之前执行一个或多个重要的操作,例如,访问敏感信息——在允许用户访问敏感信息之前,我们希望确保用户具备足够的权限。操作系统也存在类似的情况,用户必须具有管理员权限才能在系统中安...
    99+
    2023-01-31
    模式 python
  • python实现图书管理系统的代码怎么写
    这篇文章主要介绍“python实现图书管理系统的代码怎么写”,在日常操作中,相信很多人在python实现图书管理系统的代码怎么写问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”python实现图书管理系统的代码...
    99+
    2023-06-29
  • Python爬虫怎么实现搭建代理ip池
    这篇“Python爬虫怎么实现搭建代理ip池”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python爬虫怎么实现搭建代理i...
    99+
    2023-07-02
  • 简单实现Socks5代理(Python&
    只实现了CONNECT功能 参考:点击打开链接 Python版: import socket import threading import select import time IsNeedAuth=False Username=...
    99+
    2023-01-31
    简单 Python
  • 怎么用一行代码实现Python并行处理
    今天小编给大家分享一下怎么用一行代码实现Python并行处理的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。传统的例子简单搜索...
    99+
    2023-06-27
  • javascript Ajax类的实现代码
    本篇内容主要讲解“javascript Ajax类的实现代码”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript Ajax类的实现代码”吧! ...
    99+
    2024-04-02
  • Java代理模式怎么实现
    这篇文章主要讲解了“Java代理模式怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java代理模式怎么实现”吧!结构型模式前面创建型模式介绍了创建对象的一些设计模式,这节介绍的结构型...
    99+
    2023-06-02
  • 怎么在Python中实现类的单继承
    怎么在Python中实现类的单继承?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一、类的继承面向对象三要素之一,继承Inheritance人类和猫类都继承自动物类。个体继承自父...
    99+
    2023-06-15
  • 怎么实现socks5全局代理
    要实现Socks5全局代理,你可以按照以下步骤进行操作:1. 首先,你需要一个Socks5代理服务器。你可以使用开源的Socks5服...
    99+
    2023-08-19
    socks5
  • Go代理模式怎么实现
    Go语言中实现代理模式可以使用结构体和接口的方式。首先,定义一个接口,代理和被代理对象都必须实现这个接口。这里以一个简单的计算器为例...
    99+
    2023-08-08
    Go
  • python数据处理之Pandas类型转换怎么实现
    这篇文章主要介绍“python数据处理之Pandas类型转换怎么实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“python数据处理之Pandas类型转换怎么实现”文章能帮助大家解决问题。转换为字...
    99+
    2023-06-30
  • Python实现图书管理系统设计的代码怎么写
    本篇内容介绍了“Python实现图书管理系统设计的代码怎么写”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!基于python的tkinter,...
    99+
    2023-06-29
  • 怎么理解Python的元类
    本篇内容介绍了“怎么理解Python的元类”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!什么是元类Python中,一切皆对象,我们定义的数字...
    99+
    2023-06-21
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作