Use of Python metaclass I - __getattr__ for static/class variable

使用元类控制类变量访问
本文介绍了一种使用Python元类来控制类或静态变量访问的方法。通过重写`__getattr__`方法,可以自定义如何获取这些变量,从而实现更加灵活的类属性管理。

In my previous post, I disussesed with the reader the concept of metaclass and its internals.  this post is inspired from this post from stackoverflow

 

 

In this post, I will visit one of the use of meta class so so that we can control the access to the class/static variable through the use of __getattr__ call

 

 

 

class GetAttrOnStaticClassVariableMetaclass(type):
    '''
    This is a use case that uses the Metaclass to create a classes that you can access the Class/Static variable
    via call to __getattr__
    '''
    
    # due to some stupid reaon, I could not use cls as the first parameter, I have to use the 
    # self as the first parameter, which is really dume
    def _foo_func(self):
        return 'foo!'
    def _bar_func(self):
        return 'bar!'
    def __getattr__(self, key):
        if (key == 'Foo'):
            return self._foo_func()
        elif (key == 'Bar'):
            return self._bar_func()
        raise AttributeError(key)
    def __str__(self):
        return 'custom str for %s' % (self.__name__,)

 

 

and the following is the unit test case to show how to use it . 

 

 

 

import unittest
from MetaClass.GetAttrOnStaticClassVariableMetaclass import GetAttrOnStaticClassVariableMetaclass


class Test(unittest.TestCase):


    def test_getAttrOnStaticClassVariable_should_access_static_variables(self):
        class Foo:
            __metaclass__ = GetAttrOnStaticClassVariableMetaclass
        self.assertEqual(True, hasattr(Foo, "Foo"), "Unable to get Static Class variable")
        self.assertEqual(True, hasattr(Foo, "Bar"), "Unable to get Static Class variable")
        self.assertEqual('foo!', Foo.Foo, "Unable to get Static Class variable")
        self.assertEqual('bar!', Foo.Bar, "Unable to get Static Class variable")
        
if __name__ == "__main__":
    #import sys;sys.argv = ['', 'Test.testGetAttrOnStaticClassVariable_should_access_static_variables']
    unittest.main()
 

 

 

(yolo) gis@ubuntu:~/yolov11/map$ # 升级到兼容版本 pip install --upgrade python-socketio>=5.12.0 # 验证版本 pip show python-socketio | grep Version # 应显示 Version: 5.12.0 或更高 WARNING: Error parsing dependencies of cv2: [Errno 2] No such file or directory: '/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/cv2-4.10.0.dist-info/METADATA' ERROR: Exception: Traceback (most recent call last): File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_vendor/pkg_resources/__init__.py", line 3367, in _dep_map return self.__dep_map File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_vendor/pkg_resources/__init__.py", line 3147, in __getattr__ raise AttributeError(attr) AttributeError: _DistInfoDistribution__dep_map During handling of the above exception, another exception occurred: Traceback (most recent call last): File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_vendor/pkg_resources/__init__.py", line 3358, in _parsed_pkg_info return self._pkg_info File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_vendor/pkg_resources/__init__.py", line 3147, in __getattr__ raise AttributeError(attr) AttributeError: _pkg_info During handling of the above exception, another exception occurred: Traceback (most recent call last): File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_internal/cli/base_command.py", line 107, in _run_wrapper status = _inner_run() File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_internal/cli/base_command.py", line 98, in _inner_run return self.run(options, args) File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_internal/commands/show.py", line 57, in run if not print_results( File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_internal/commands/show.py", line 187, in print_results for i, dist in enumerate(distributions): File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_internal/commands/show.py", line 126, in search_packages_info required_by = sorted(_get_requiring_packages(dist), key=str.lower) File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_internal/commands/show.py", line 107, in <genexpr> in {canonicalize_name(d.name) for d in dist.iter_dependencies()} File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_internal/metadata/pkg_resources.py", line 244, in iter_dependencies return self._dist.requires(extras) File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_vendor/pkg_resources/__init__.py", line 3070, in requires dm = self._dep_map File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_vendor/pkg_resources/__init__.py", line 3369, in _dep_map self.__dep_map = self._compute_dependencies() File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_vendor/pkg_resources/__init__.py", line 3378, in _compute_dependencies for req in self._parsed_pkg_info.get_all('Requires-Dist') or []: File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_vendor/pkg_resources/__init__.py", line 3360, in _parsed_pkg_info metadata = self.get_metadata(self.PKG_INFO) File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_vendor/pkg_resources/__init__.py", line 1672, in get_metadata value = self._get(path) File "/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/pip/_vendor/pkg_resources/__init__.py", line 1886, in _get with open(path, 'rb') as stream: FileNotFoundError: [Errno 2] No such file or directory: '/home/gis/miniconda3/envs/yolo/lib/python3.10/site-packages/cv2-4.10.0.dist-info/METADATA'
11-13
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值