zoukankan      html  css  js  c++  java
  • 27 isinstance与issubclass、反射、内置方法

    isinstance与issubclass

    issubclass:判断子类是否属于父类,是则返回True,否则返回False

    isinstance:判断对象是否属于类,是则返回True,否则返回False

    class Bar:
        pass
    
    class Foo(Bar):
        pass
    
    print(issubclass(Foo,Bar))#输出一个True
    obj=Foo()
    
    print(isinstance(obj,Foo))#输出一个True

    反射

    反射:通过字符串来反射/映射到对象/类的属性上
    class People:
        def __init__(self,name,age):
            self.name=name
            self.age=age
    
        def run(self):
            print('%s is running' %self.name)
    
    
    obj=People('egon',18)
    
    print(hasattr(obj,'name')) # 'name' in obj.__dict__  判断属性是否在__dict__里
    print(getattr(obj,'name')) # obj.__dict__['name']    从__dict__里获取name,没有则会报错
    print(getattr(obj,'xxx',None)) # obj.__dict__['xxx'] 设置没有找到返回None
    
    setattr(obj,'name','EGON') #obj.__dict__['name']='EGON'  更新
    setattr(obj,'xxx',1111) #obj.__dict__['xxx']=111
    
    delattr(obj,'name')

    内置方法


    # __str__: 在对象被打印时自动触发,可以用来定义对象被打印时的输出信息
    # 注意:必须返回一个字符串类型的值
    class People:
        def __init__(self, name, age):
            self.name = name
            self.age = age
    
        def __str__(self):
            print('run..........')
            return '<name:%s age:%s>' % (self.name, self.age)
    
    
    obj1 = People('egon', 18)
    print(obj1)  # print(obj1.__str__())
    View Code

    # __del__: 在对象被删除时先自动触发该方法,可以用来回收对象以外其他相关资源,比如系统资源
    class Foo:
        def __init__(self,x,filepath,encoding='utf-8'):
            self.x=x
            self.f=open(filepath,'rt',encoding=encoding)
    
        def __del__(self):
            print('run.....')
            # 回收对象关联的其他资源
            self.f.close()
    
    obj=Foo(1,'a.txt')
    del obj
    print('主===========>')
    View Code

    # __call__: 在对象被调用时会自动触发该方法,可以用来???
    # __call__: 在对象被调用时会自动触发该方法,可以用来???
    View Code


  • 相关阅读:
    Android手势锁实现
    网页模板pug基本语法
    React入门看这篇就够了
    我曾站在离你最近的天涯
    一文看懂浏览器事件循环
    Vi编辑网卡
    2019.6.11_MySQL进阶二:主键与外键
    2019.6.13_笔试题目及答案
    2019.6.13_MySQL简单命令的使用
    2019.6.13_SQL语句中----删除表数据drop、truncate和delete的用法
  • 原文地址:https://www.cnblogs.com/ouyang99-/p/10415413.html
Copyright © 2011-2022 走看看