Python之metaclass和dataclass
创始人
2024-05-30 00:17:18
0

metaclass:

MetaClass元类,本质也是一个类,但和普通类的用法不同,它可以对类内部的定义(包括类属性和类方法)进行动态的修改。可以这么说,使用元类的主要目的就是为了实现在创建类时,能够动态地改变类中定义的属性或者方法。

举个例子,根据实际场景的需要,我们要为多个类添加一个 name 属性和一个 say() 方法。显然有多种方法可以实现,但其中一种方法就是使用 MetaClass 元类。

如果在创建类时,想用 MetaClass 元类动态地修改内部的属性或者方法,则类的创建过程将变得复杂:先创建 MetaClass 元类,然后用元类去创建类,最后使用该类的实例化对象实现功能。

如果想把一个类设计成 MetaClass 元类,其必须符合以下条件:

  1. 必须显式继承自 type 类;

  1. 类中需要定义并实现 __new__() 方法,该方法一定要返回该类的一个实例对象,因为在使用元类创建类时,该 __new__() 方法会自动被执行,用来修改新建的类。

metaclass 是 type 的子类,通过替换 type的__call__运算符重载机制,“超越变形”正常的类。

一旦你把一个类型 Student 的 metaclass 设置成 Human,Student 就不再由原生的 type创建:

class Human(type):def __new__(mcs, *args, **kwargs):class_ = super().__new__(mcs, *args)for key, value in kwargs.items():setattr(class_, key, value)return class_class Student(object, metaclass=Human, country="China", freedom=True):passprint(Student.freedom)
print(Student.country)

实现一个根据props = ["name", "age"] 动态添加实例属性的metaclass:Human

class Prop:def __init__(self, attr):self._attr = f"_{attr}"def get(self, obj):if not hasattr(obj, self._attr):return Nonereturn getattr(obj, self._attr)def set(self, obj, value):setattr(obj, self._attr, value)class Human(type):def __new__(mcs, *args, **kwargs):class_ = super().__new__(mcs, *args)for property_name in class_.props:prop = Prop(property_name)prop_value = property(fget=prop.get, fset=prop.set)setattr(class_, property_name, prop_value)return class_class Student(object, metaclass=Human):props = ["name", "age"]student = Student()print(student.name)
student.name = "KbZswWtl"
print(student.name)

用装饰器的形式来进行metadata的封装:

class Prop:def __init__(self, attr):self._attr = f"_{attr}"def get(self, obj):if not hasattr(obj, self._attr):return Nonereturn getattr(obj, self._attr)def set(self, obj, value):setattr(obj, self._attr, value)class Human(type):def __new__(mcs, *args, **kwargs):class_ = super().__new__(mcs, *args)for property_name in class_.props:prop = Prop(property_name)prop_value = property(fget=prop.get, fset=prop.set)setattr(class_, property_name, prop_value)return class_def human(cls):return Human(cls.__name__, cls.__bases__, dict(cls.__dict__))class Student(object, metaclass=Human):props = ["name", "age"]@human
class Man:props = ["name", "age"]man = Man()
print(man.name)
man.name = "Tom"
print(man.name)student = Student()print(student.name)
student.name = "KbZswWtl"
print(student.name)

dataclass:

Python 内置装饰器可降低代码的复杂性和长度

Python中的面向对象编程(OOP)一直是热门话题之一。这是因为 Python 之所以出名,是因为它的灵活性和开箱即用的特性可以在很大程度上减少开发工作量,OOP 也是如此。

他们都需要利用 3rd 方库,但它们仍然是很好的解决方案。

这里介绍一个 Python 内置模块——Dataclass。它是在 Python 3.7 中引入的,它使开发人员能够以面向对象的方式进行编码,而无需任何 3rd 方库。数据类提供了开箱即用的方法来创建自定义数据, 可以直接实例化、打印和比较数据类实例。

from dataclasses import dataclass@dataclass
class Student:name: strage: ints_1 = Student()

从上面可以看出,@dataclass装饰器给我们的类中自动添加了__init__(self,name,age)函数

from dataclasses import dataclass@dataclass
class Student:name: strage: ints_1 = Student("KbZswWtl", 31)
s_2 = Student("KbZswWtl", 31)print(s_1)
print(s_2)print(s_1 == s_2)

从上面可以看出,@dataclass装饰器也给我们的类中添加了__str__、判等的函数

from dataclasses import dataclass@dataclass
class Student:name: strage: int = 18s_1 = Student("KbZswWtl")
s_2 = Student("KbZswWtl")print(s_1)
print(s_2)

从上面可以看出,@dataclass装饰器也给我们的类中添加了__init__默认值的操作

相关内容

热门资讯

克罗恩病关节炎:身体与心灵的双... 哎呀,说到这个克罗恩病关节炎,真是让我又爱又恨啊!你可能觉得我这话有点夸张,但当你真正感受到它带来的...
胃病不能吃什么-胃病发作时,这... 哎呀,说到胃病,我这肚子就开始隐隐作痛了。你们知道吗,胃病发作的时候,有些食物简直就是“毒药”!首先...
exe文件用手机能打开-手机能... 哎呀,今天咱们来聊聊这个听起来有点玄乎的话题——手机能打开exe文件?我得先说,这可不是闹着玩的!e...
华为新视通视频会议方案:技术进... 大家好!今天我要和大家聊聊华为新出的那个“新视通”视频会议方案。哇,这个名字听起来就很有未来感,对吧...
exagear模拟器使用方法-... 嘿,各位游戏迷们,今天我要来聊聊一个超级酷炫的工具——Exagear模拟器!是不是有时候看到那些老旧...
sd卡格式化后数据自动恢复-S... 哎呀,说到这个SD卡格式化后数据自动恢复的事儿,真是让人又爱又恨!你知道吗,有一次我不小心把SD卡给...
帝国cms模板文件目录-帝国 ... 哎呀,说到这个帝国CMS的模板文件目录,我可是有一肚子的话要说!这玩意儿啊,真是个让人又爱又恨的小妖...
台湾快递单号查询网:让人心急又... 哎呀,说到这个台湾快递单号查询网,我真是又爱又恨!每次网购完,最让人心急的就是等快递了。你知道的,那...
酷管家损坏照片修复:拯救珍贵记... 哎呀,说到这个酷管家损坏照片修复,我这心里就五味杂陈啊!记得那次,我辛辛苦苦攒了几个月的照片,突然间...
live linux-体验自由... 嘿,朋友们,今天咱们聊聊那个让人爱不释手的LiveLinux!想象一下,你的电脑不再是被某个大公司绑...
phantomjs win10... 哎呀,说到在Win10上安装PhantomJS,这可真是一次让人又爱又恨的经历!你知道的,作为一个对...
西软酒店管理系统 官网-西软酒... 大家好,我是一名酒店前台的小姐姐,今天我要来聊聊我们酒店用的那个“西软酒店管理系统”官网,真的是让我...
出生医学证明大小太奇葩,让人又... 你知道吗,每次提到那个小小的出生医学证明,我心里就五味杂陈。不是因为它有多重要,而是因为它的大小,简...
路由器宽带叠加:让你家网速翻倍... 哎呀呀,说到这个路由器宽带叠加,我这小心脏就扑通扑通跳个不停!你知道吗,自从我用了这个神奇的技巧,我...
finaldata4.1注册码... 哎呀,说到这个FinalData4.1的注册码,真是让人又爱又恨啊!你知道吗,这玩意儿就像是那个关键...
多媒体教室讲台3d模型-多媒体... 哇,今天我要给大家带来一个超级酷炫的话题——我们的多媒体教室讲台3D模型!你们有没有想过,那个每天站...
手机看交通监控摄像头-在手机上... 在这个快节奏的城市生活中,我找到了一个小小的秘密花园——手机上的交通监控摄像头。每当我觉得压力山大,...
win10 老驱动-Win10... 哎呀,说到这个Win10的老驱动,我就一肚子火!你们知道吗,每次系统更新,我的电脑就像要和我闹别扭一...
急性呼吸衰竭定义-急性呼吸衰竭... 想象一下,你的肺突然像被重物压住,每一次呼吸都变成了一场挣扎。这就是急性呼吸衰竭的感觉,它像是一个不...
华天动力oa办公系统-华天动力... 大家好!我是你们的小助手,今天想和大家聊聊那个让我们的工作日变得稍微有点乐趣的家伙——华天动力OA办...