元类练习题

练习一:在元类中控制把自定义类的数据属性都变成大写

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}
"""

 

转载于:https://www.cnblogs.com/xiugeng/p/8944780.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值