元类练习题
练习一:在元类中控制把自定义类的数据属性都变成大写
class Mymetaclass(type): def __new__(cls, name, bases, attrs): update_attrs={} for k,v in attrs.items(): if not callable(v) and not k.startswith('__'): update_attrs[k.upper()] = v else: update_attrs[k]=v return type.__new__(cls, name, bases, update_attrs) class Chinese(metaclass=Mymetaclass): country = 'China' tag = 'Legend of the Dragon' def walk(self): print('%s is walking' %self.name) print(Chinese.__dict__) """ {'__module__': '__main__', 'COUNTRY': 'China', 'TAG': 'Legend of the Dragon', 'walk': <function Chinese.walk at 0x1040211e0>, '__dict__': <attribute '__dict__' of 'Chinese' objects>, '__weakref__': <attribute '__weakref__' of 'Chinese' objects>, '__doc__': None} """
练习二:在元类中控制自定义的类无需init方法
1.元类帮其完成创建对象,以及初始化操作;
2.要求实例化时传参必须为关键字形式,否则抛出异常TypeError: must use keyword argument
3.key作为用户自定义类产生对象的属性,且所有属性变成大写
class Mymetaclass(type): def __call__(self, *args, **kwargs): if args: raise TypeError('must use keyword argument for key function') obj = object.__new__(self) # 创建对象,self为类Foo for k,v in kwargs.items(): obj.__dict__[k.upper()] = v return obj class Chinese(metaclass=Mymetaclass): country = 'China' # 需要大写的数据属性 tag = 'Legend of the Dragon' def walk(self): print('%s is walking' %self.name) p=Chinese(name='Jack', age=18, sex='male') print(Chinese.__dict__) """ {'__module__': '__main__', 'country': 'China', 'tag': 'Legend of the Dragon', 'walk': <function Chinese.walk at 0x1040211e0>, '__dict__': <attribute '__dict__' of 'Chinese' objects>, '__weakref__': <attribute '__weakref__' of 'Chinese' objects>, '__doc__': None} """