python 内置函数的补充 isinstance,issubclass, hasattr ,getattr, setattr, delattr,str,del 用法,以及元类

isinstance   是 python中的内置函数 , isinstance()用来判断一个函数是不是一个类型

issubclass  是python 中的内置函数,  用来一个类A是不是另外一个类B的子类   issubclass(子类,父类)

class Foo:
    pass

obj=Foo()
print(isinstance(obj,Foo))#  判断实例化的foo是不是这个类
#判断结果为True

print(isinstance(obj,Foo)) 它就等同于
======》》》print(type(obj) is Foo) #obj的类是Foo

再举个例子:

print(isinstance('abc',str))   字符串的类是 str
print(isinstance(123,int))      数字的类是 int


 

反射:通过字符串来操作类与对象的属性,  这种操作成为反射

有四个   hasattr         getattr          setattr       delattr  

这四个的用法 都为hasattr /setarr/getattr/delattr (类名,‘字符串’)类名后面加的都是字符串
 
class People:
    country ='china'
    def __init__(self,name):
        slef.name=name
    def tell(self):
        print('%s is aaa'%self.name)

obj=People('egon')

#1、hasattr  判断有没有这个属性
print(hasattr(People,'country'))  #True
====>> 等同于
 print('country' in People.__dict__)


#2、getattr  函数属于内置函数, 可以通过函数名获取

x=getattr(People,'country')
print(x)    #打印结果  China

若是获取的类里没有这个属性  则在字符串后加个 None  不然的话会报错

 x=getattr(People,'country1',None)
 print(x)


#3、setarr  通过这个函数来设置属性 添加属性

setattr(People,'x',111)
print(People.x)  
#打印结果为  111
 
#4、delattr  用来删除对象的属性
delattr(People,"country")
print(People.__dict__)

#{'__module__': '__main__', '__init__': <function People.__init__ at 0x00000138FC835048>, 'tell': <function People.tell at 0x00000138FC8350D0>, '__dict__': <attribute '__dict__' of 'People' objects>, '__weakref__': <attribute '__weakref__' of 'People' objects>, '__doc__': None}
   在来看  country 这个属性已经删掉了

 

__str__ 方法:如果要把一个类的实例 变成str,就需要实现特殊方法__str__(),下面说 怎么用:

我想要拿到egon的个人信息  姓名年龄以及性别 要是按照如下就很难拿到

class People:
    def __init__(self,name,age,sex):
        self.name =name
        self.age=age
        self.sex=sex

obj=People('egon',18,'male')
print(obj)

#打印结果
<__main__.People object at 0x0000021FCE461B00>


要是拿到信息 就地像以下方法拿到
print(obj.name)
print(obj.age)
print(obj.sex)
#打印结果
egon
18
male
这样就感觉比较复杂  可以在类内部添加一个__str__ 函数 试试呢



class People:
    def __init__(self,name,age,sex):
        self.name =name
        self.age=age
        self.sex=sex

    def __str__(self):
        return '名字:%s,年龄:%s,性别:%s'%(self.name,self.age,self.sex)

obj=People('egon',18,'male')
print(obj)
#打印结果
名字:egon,年龄:18,性别:male

__del__方法  删除

当对象在内存中被释放时, 自动触发执行

如果产生的对象仅仅只是在python程序级别的(用户级), 那么无需定义__del__,如果产生的对象的同时 还会像操作系统发起系统调用,即一个对象有用户级与内核级两种资源, 比如(打开一个文件, 创建一个数据库连接,)则必须在清楚对象的同时 回收系统资源 这就用到了__del__.

class Foo:
    def __del__(self):
        print('执行我了’)

f1=Foo()
del f1
print('------->')

#输出结果
执行我了
------->

 

 

元类:元类就是帮你创建类的‘家伙‘,在python中, 类也是对象,这样的对象就是通过袁磊创建的, 元类就是‘类的类’。之前提到的type实际上就是元类, 在python中所有的类都是用type创建的。到此我们也能够立即为什么说在python中一切皆对象了吧,int,string,function,以及class 

所有的多少对象 ,他们都能够从一个类中创建。

2、用内置的元类type,来实例化得到我们的类
class_name='Chinese'       #创建类名
class_bases=(object,)     #定义父类
class_body="""         #定义类的特征与属性等代码体
country="China"
def __init__(self,name,age,sex):
    self.name=name
    self.age=age
    self.sex=sex
def speak(self):
    print('%s speak Chinese' %self.name)
"""
class_dic={}       #目前类的属性里的名称空间名字都还为空    
exec(class_body,{},class_dic)   #exec 括号里面是代码体,然后是全局名称空间里的名称, 再然后是局部名称空间里的名称,全局的名称空间没有, 局部的名称空间会在类里产生。 

类的三大要素
print(class_name,class_bases,class_dic)  #类的三大要素,类名。父类,已经类的属性(名称空间包括变量以及函数)

Chinese=type(class_name,class_bases,class_dic)   #创建类
print(Chinese)

p=Chinese('egon',18,'male')
print(p.name,p.age,p.sex)

 

__call__:  调用对象 会自动触发对象下的绑定方法__call__的执行,

然后将对象本身当做第一个参数传给self,将调用对象时 括号内的值传给*args,**kwargs

def __call__(self,*args,**kwargs):

  print('__call__'args,kwargs)

 

posted @ 2018-04-17 16:35  C3的脚印  阅读(291)  评论(0编辑  收藏  举报