Python 中的元类是用来创建类的类。元类允许我们在创建类时动态地修改类的定义。
在 Python 中,一切皆对象,包括类。因此,类本身也是一个对象,而这个对象的类就是元类。
元类可以用于以下情况:
- 控制类的创建过程:可以通过元类来自定义类的创建过程,例如加上一些额外的属性或方法。
- 类型检查:可以通过元类来确保类的定义符合某些规则或约束。
- 自动注册:可以通过元类自动注册类的实例。
"""
元类
type 返回变量的类型
type 创建一个新的类型,控制加工类的创还能过程
"""
# class Person:
# pass
#
#
# p = Person()
# # 实例p由类Person创建
# print(type(p))
# # 类Person由type类创建 type类用于创建类(元类)
# print(type(Person))
# print(type(type))
# def __init__(self, name, age):
# self.name = name
# self.age = age
#
#
# # MyClass 只是类的别名 第一个询过擦边 Person 才是真正类名
# # 第二个形参是父类元组
# # 第三个形参是类属性字典
# MyClass = type("Person", (object,), {"__doc__": """我是type创建出来的Person类""",
# "__init__": __init__,
# "__str__": lambda self: f"name: {self.name} age:{self.age}"
# })
#
# print(type(MyClass), callable(MyClass), MyClass.__name__, MyClass.__bases__, MyClass.__doc__)
#
# p0 = MyClass("张飞", 20)
# print(p0)
from tkinter import Label
class MyMetaClass(type):
def __new__(cls, *args, **kwargs):
# args 包含创建类的信息
print(args, kwargs)
# 加工类内容(类注释)
args[2]["__doc__"] = "醒醒啦,好好学习,天天睡觉"
# 加工父类
parent_class = (Label, )
# 构造新类
MyClass = type(f"ZZY_{args[0]}", parent_class, args[2])
return MyClass
# metaclass 元类 执行使用哪个类来创建新类 可定是type的子类
class Person(object, metaclass=MyMetaClass):
"""我是type创建出来的Person类"""
def __init__(self, name, age):
self.name = name
self.age = age
def __str__(self):
return f"name: {self.name} age:{self.age}"
print(type(Person), callable(Person), Person.__name__, Person.__bases__, Person.__doc__)
p0 = Person("张飞", 20)
print(p0)