zoukankan      html  css  js  c++  java
  • 用类的内置方法实现类型检查

    1.利用重写__setattr__来实现。

    import logging
    
    logger = logging.getLogger('logger')
    streamhandler = logging.StreamHandler()
    logger.setLevel(logging.DEBUG)
    streamhandler.setLevel(logging.DEBUG)
    streamhandler.setFormatter(logging.Formatter(
        '%(asctime)s - %(name)s - %(levelname)s - %(message)s'))
    logger.addHandler(streamhandler)
    
    
    def typeassist(**kwargs):
        def new_cls(cls):
            def redefine(self, key, value):
                if not isinstance(value, kwargs[key]):
                    logger.log(level=logging.ERROR, msg='TypeError')
                    self.__dict__[key] = None
                else:
                    self.__dict__[key] = value
            setattr(cls, '__setattr__', redefine)
            return cls
        return new_cls
    
    
    @typeassist(name=str, age=int, result=float)
    class Student:
        def __init__(self, name, age, result):
            self.name = name
            self.age = age
            self.result = result
    
        def __str__(self):
            return str(self.__dict__)
    
    
    m = Student('sasd', 56, 45.0)
    p = Student('SSS', 12, 4)
    print(p)
    print(m)

    2.利用描述符来实现。

    import logging
    
    logger = logging.getLogger('logger')
    streamhandler = logging.StreamHandler()
    logger.setLevel(logging.DEBUG)
    streamhandler.setLevel(logging.DEBUG)
    streamhandler.setFormatter(logging.Formatter(
        '%(asctime)s - %(name)s - %(levelname)s - %(message)s'))
    logger.addHandler(streamhandler)
    
    
    class Descriptor:
        def __init__(self, attrname, attrtype):
            self.attrname = attrname
            self.attrtype = attrtype
    
        def __set__(self, instance, value):
            if not isinstance(value, self.attrtype):
                logger.log(level=logging.ERROR, msg='TypeError')
                self.__dict__[instance] = None
                instance.__dict__[self.attrname] = None  # 注意,此处是为了维护属性字典的统一性
            else:
                self.__dict__[instance] = value
                instance.__dict__[self.attrname] = value  # 同上
    
        def __get__(self, instance, owner):
            return self.__dict__[instance]
    
    
    def typeassist(**kwargs):
        def new_cls(cls):
            for attrname, attrtype in kwargs.items():
                setattr(cls, attrname, Descriptor(attrname, attrtype))
            return cls
        return new_cls
    
    
    @typeassist(name=str, age=int, result=float)
    class Student:
        def __init__(self, name, age, result):
            self.name = name
            self.age = age
            self.result = result
    
        def __str__(self):
            return str(self.__dict__)
    
    
    m = Student('sasd', 56, 45.0)
    p = Student('SSS', 12, 4)
    print(p)
    print(m)
  • 相关阅读:
    工具推荐-根据IP地址精确定位经纬度(永久免费)
    VMware与Centos系统安装
    Python 之ConfigParser模块
    Python记录日志模块推荐-loguru!
    Excel 两列单元格合并超级链接的VBA 写法
    Shell脚本日志关键字监控+告警
    Python字符串及基本操作(入门必看)!!
    github release 下载文件慢、或者失败的解决方法
    Python字典及基本操作(超级详细)
    为什么使用 Containjs 模块化管理工具效率高?
  • 原文地址:https://www.cnblogs.com/poincare/p/9094746.html
Copyright © 2011-2022 走看看