day 23 内置函数 + 反射

内置函数type() ,isinstance(),issubclass()

  type() 是用来检测 一个对象和一个类有没有血缘关系    print(type((a) is A))

  isinstance() 是用来检测 对象和父类之间有没有继承关系,包括了type()的功能   print(isinstance(a,B))

  issubclass() 是用来检测 子类和父类之间有没有血缘关系。print(issubclass(A,B))  格式(子类名在前,父类名在后)

  

反射:


  # 正常情况下如果可以拿到这个变量 那么如有有这个变量的字符串形式 就是用反射可以获取到这个值
  # 使用字符串数据类型的变量名 访问一个命名空间中的名字
  # 找一个属性 ,直接就可以找到这个属性的值
  # 找一个方法 ,找到的是这个方法的内存地址
  # hasattr() 判断一个命名空间中有没有这个名字
  # getattr() 从命名空间中获取这个名字对应的值
  #类中的反射
      类可以获取类中的属性和方法
hasattr(类名/对象名/模块名,属性/方法)   判断类/模块里是否有属性/方法
getattr(类名/对象名/模块名,属性/方法)
setattr(类名/对象名/模块名,属性/方法,新属性的值/新方法的名字(这个名字不加引号))
delattr(类名/对象名/模块名,属性/方法)

应用场景:
  类使用类命名空间中的名字
  # 对象使用对象能用的方法和属性
  # 模块使用模块中的名字
# import os ; getattr(os,'rename')('user','user_info')
  # 从自己所在的模块中使用自己名字



反射


1 什么是反射


反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问、检测和修改它本身状态或行为的一种能力(自省)。这一概念的提出很快引发了计算机科学领域关于应用反射性的研究。它首先被程序语言的设计领域所采用,并在Lisp和面向对象方面取得了成绩。




2 python面向对象中的反射:通过字符串的形式操作对象相关的属性。python中的一切事物都是对象(都可以使用反射)


四个可以实现自省的函数


下列方法适用于类和对象(一切皆对象,类本身也是一个对象)


复制代码
def hasattr(*args, **kwargs): # real signature unknown
    """
    Return whether the object has an attribute with the given name.
    
    This is done by calling getattr(obj, name) and catching AttributeError.
    """
    pass
复制代码

复制代码
def getattr(object, name, default=None): # known special case of getattr
    """
    getattr(object, name[, default]) -> value
    
    Get a named attribute from an object; getattr(x, 'y') is equivalent to x.y.
    When a default argument is given, it is returned when the attribute doesn't
    exist; without it, an exception is raised in that case.
    """
    pass
复制代码

复制代码
def setattr(x, y, v): # real signature unknown; restored from __doc__
    """
    Sets the named attribute on the given object to the specified value.
    
    setattr(x, 'y', v) is equivalent to ``x.y = v''
    """
    pass
复制代码

复制代码
def delattr(x, y): # real signature unknown; restored from __doc__
    """
    Deletes the named attribute from the given object.
    
    delattr(x, 'y') is equivalent to ``del x.y''
    """
    pass
复制代码

关于对象
复制代码
class Foo:
    f = '类的静态变量'
    def __init__(self,name,age):
        self.name=name
        self.age=age

    def say_hi(self):
        print('hi,%s'%self.name)

obj=Foo('egon',73)

#检测是否含有某属性
print(hasattr(obj,'name'))
print(hasattr(obj,'say_hi'))

#获取属性
n=getattr(obj,'name')
print(n)
func=getattr(obj,'say_hi')
func()

print(getattr(obj,'aaaaaaaa','不存在啊')) #报错

#设置属性
setattr(obj,'sb',True)
setattr(obj,'show_name',lambda self:self.name+'sb')
print(obj.__dict__)
print(obj.show_name(obj))

#删除属性
delattr(obj,'age')
delattr(obj,'show_name')
delattr(obj,'show_name111')#不存在,则报错

print(obj.__dict__)
复制代码



关于类
复制代码
class Foo(object):
 
    staticField = "old boy"
 
    def __init__(self):
        self.name = 'wupeiqi'
 
    def func(self):
        return 'func'
 
    @staticmethod
    def bar():
        return 'bar'
 
print getattr(Foo, 'staticField')
print getattr(Foo, 'func')
print getattr(Foo, 'bar')
复制代码



反射当前文件中的名字
复制代码
#!/usr/bin/env python
# -*- coding:utf-8 -*-

import sys


def s1():
    print 's1'


def s2():
    print 's2'


this_module = sys.modules[__name__]

hasattr(this_module, 's1')
getattr(this_module, 's2')
复制代码

导入其他模块,利用反射查找该模块是否存在某个方法


#!/usr/bin/env python
# -*- coding:utf-8 -*-

def test():
    print('from the test')

复制代码
#!/usr/bin/env python
# -*- coding:utf-8 -*-
 
"""
程序目录:
    module_test.py
    index.py
 
当前文件:
    index.py
"""

import module_test as obj

#obj.test()

print(hasattr(obj,'test'))

getattr(obj,'test')()
复制代码
 
原文地址:https://www.cnblogs.com/zsdbk/p/8886426.html