一、反射机制 *

  反射可以理解为

  • 通过字符串的形式,动态导入模块;
  • 利用字符串的形式,在对象(模块)中操作(查找/获取/删除/添加)成员,是一种基于字符串的事件驱动!

  反射机制的内置函数

 # hasattr(object,attr)
# 输入两个参数(对象,字符串类型(方法或属性)),判断一个对象里是否有某个属性或方法,返回布尔值,有为True,否则False
class Foo:
def f1(self):
pass
obj = Foo()
print(hasattr(obj,"f1"))
# 运行结果:True # getattr(object,attr[,default])
# 获取对象的属性或方法,可设置输出默认值,
# 如果获取方法,返回的是内存地址,如果需要运行,后面添加一对括号
class Foo:
def f1(self):
print("获取了f1方法")
obj = Foo()
ret = getattr(obj,"f1")
ret()
print(ret)
# 运行结果:获取了f1方法 \
# <bound method Foo.f1 of <__main__.Foo object at 0x0000024FE505E9B0>> # setattr(object,attr,values)
# 动态的给对象的属性赋值(内存地址),若属性不存在,则先创建再赋值
class Foo:
def __init__(self,a1):
self.a1 = a1
obj = Foo(1)
print(getattr(obj,"a1"))
#运行结果:1
setattr(obj,"a1",2) # 将对象中的属性重新赋值
print(getattr(obj,"a1"))
#运行结果:2
setattr(obj,"a2",3) #在对象中创建一个新的属性a2并赋值
print(getattr(obj,"a2"))
#运行结果:3 # delattr(object,attr,values)
# 动态的删除对象的属性(内存地址)
class Foo:
def __init__(self,a1):
self.a1=a1
obj = Foo(1)
print(getattr(obj,"a1"))
# 运行结果: 1
setattr(obj,"a2",2)
print(getattr(obj,"a2"))
# 运行结果: 2
delattr(obj,"a2")
print(getattr(obj,"a2")) #删除对象中的属性
#运行结果:AttributeError: 'Foo' object has no attribute 'a2'

反射的内置函数

二、如何正确的判断方法与函数?

  目前我们印象中的方法就是封装在类内部的函数,实际上这样说不严谨;

  

 # 如何判断方法与函数
# tpye
# 判断类型
class Foo:
def f1(self):
pass
obj = Foo()
print(obj,type(obj.f1)) # 当我们用对象调用类中的方法时,我们通过type查看到的是方法
# 运行结果:<__main__.Foo object at 0x0000028E0F10E898> <class 'method'>
print(Foo,type(Foo.f1)) # 当我们用类调用类中的方法时,我们通过type查看到的是函数
# 运行结果:<class '__main__.Foo'> <class 'function'>
# 总结:封装在类中的函数通过对象调用时是真正的方法。

三、callattr()、issubclass()、isinstance、type()的使用

  callattr()方法是用来判断传入的参数是否可以被调用

 callable
判断输入的参数是否可以被调用
class Foo:
def f1(self):
pass
def __call__(self, *args, **kwargs):
pass
def func():
pass
obj = Foo()
print(callable(Foo)) # 类是可以被调用的类型
# 运行结果: True
print(callable(obj.f1)) # 方法是可以被调用的类型
# 运行结果: True
print(callable(func)) #函数是可以被调用的类型
# 运行结果: True
print(callable(obj)) #实例化的对象是可以被调用的类型,注:类的内部要有__call__方法
# 运行结果: True

  issubclass()方法是用判断传入的两个参数,前一个参数是否是后一个参数的派生类

 # issubclass
# 判断传入的两个参数,前一个参数是否是后一个参数的子类
class Base:
pass
class Foo(Base):
pass
print(issubclass(Foo,Base))
# 运行结果: True

  isinstance()方法是判断传入两个参数,第一个传入的参数(对象),是否是第二个参数(类)的实例

  

 # isinstance
# 判断传入两个参数,第一个传入的参数(对象),是否是第二个参数(类)的实例
class Base:
def f1(self):
pass
def f2(self):
pass
class Foo(Base):
def f1(self):
pass
class Last:
pass
obj = Foo()
print(isinstance(obj,Last))
#运行结果:False
print(isinstance(obj,Foo)) # obj是Foo类的一个实例化对象
#运行结果:True
print(isinstance(obj,Base))# obj也可以是Foo基类的一个实例化对象
#运行结果:True
# 总结:isinstance可以判断对象是否是类或类的基类中的实例

  type()

 # type
# 判断传入的参数(对象)是哪个类的实例化对象
class Base:
pass
class Foo(Base):
pass
obj = Foo()
print(obj,type(obj)) # 获取当前对象是由哪个类创建
# 运行结果: <__main__.Foo object at 0x000001567FC9E8D0> <class '__main__.Foo'>

python之反射机制与callattr()、issubclass()、isinstance、type()相关的更多相关文章

  1. python的反射机制

    转载自:http://www.cnblogs.com/feixuelove1009/p/5576206.html 对编程语言比较熟悉的朋友,应该知道"反射"这个机制.Python作 ...

  2. 简单谈谈python的反射机制

    转:http://www.jb51.net/article/87479.htm 本文主要介绍python中的反射,以及该机制的简单应用,熟悉JAVA的程序员,一定经常和Class.forName打交道 ...

  3. 【转】简单谈谈python的反射机制

    [转]简单谈谈python的反射机制 对编程语言比较熟悉的朋友,应该知道“反射”这个机制.Python作为一门动态语言,当然不会缺少这一重要功能.然而,在网络上却很少见到有详细或者深刻的剖析论文.下面 ...

  4. 详解python之反射机制

    一.前言 def f1(): print('f1') def f2(): print('f2') def f3(): print('f3') def f4(): print('f4') a = 1 t ...

  5. Python之反射机制

    什么是反射? 1.有时我们要访问某个变量或是方法时并不知道到底有没有这个变量或方法,所以就要做些判断.判断是否存在字符串对应的变量及方法.2.我们知道访问变量时是不能加引号的,否则会被当成字符串处理. ...

  6. Python 的反射机制

    什么叫做反射 利用字符串的形式去对象(模块)中操作(查找/添加/获取/删除)成员,一种基于字符串的事件驱动. 可以使用反射动态地创建类型的实例,将类型绑定到现有对象,或从现有对象中获取类型.然后,可以 ...

  7. python面向对象--反射机制

    class Black: feture="ugly" def __init__(self,name,addr): self.addr=addr self.name=name def ...

  8. python反射机制深入分析

    对编程语言比较熟悉的朋友,应该知道“反射”这个机制.Python作为一门动态语言,当然不会缺少这一重要功能.然而,在网络上却很少见到有详细或者深刻的剖析论文.下面结合一个web路由的实例来阐述pyth ...

  9. python 反射机制在实际的应用场景讲解

    剖析python语言中 "反射" 机制的本质和实际应用场景一. 前言 def s1(): print("s1是这个函数的名字!") s = "s1&q ...

随机推荐

  1. 利用eclipse导入jar包到本地仓库

    如果不也不想用mvn install xxxxxx 后面跟一大堆的东东,可以让eclipse替代完成导入,看下图 File------->Import 大功告成,可见eclipse还没有废掉,至 ...

  2. 集合运算 & 聚合函数

    SQL 查询之集合运算 & 聚合函数   1.集合运算 1.1.并集运算 UNION 1.2.差集运算 EXCEPT 1.3.交集运算 INTERSECT 1.4.集合运算小结 2.聚合函数 ...

  3. flask 密钥问题

    RuntimeError RuntimeError: The session is unavailable because no secret key was set. Set the secret_ ...

  4. CSS 常用效果--持续更新

    单行超出省略: white-space: nowrap; text-overflow:ellipsis; overflow:hidden; 多行超出省略: text-overflow: -o-elli ...

  5. python线程池ThreadPoolExecutor(上)(38)

    在前面的文章中我们已经介绍了很多关于python线程相关的知识点,比如 线程互斥锁Lock / 线程事件Event / 线程条件变量Condition 等等,而今天给大家讲解的是 线程池ThreadP ...

  6. 035 Android 广播(BroadCastReceiver)

    1.介绍 2.实现方法 3.注册广播 (1)静态广播 在AndroidManifest.xml文件中注册广播 <intent-filter>为过滤器 <receiver androi ...

  7. Tp5.1 管理后台开发纪要

    1. tp5.1 对网页是有缓存机制的 E:\phpStudy\PHPTutorial\WWW\NewAdmin\thinkphp\library\think\Template.php 下displa ...

  8. java多线程中篇(一) —— Thread详情

    简介 简言之,现在的JDK线程模型基于操作系统原生线程,所以模型依赖于操作系统对线程的支持,另外Windows和Linux系统提供的线程模型就是一对一的 所以可以简单认为: 现在Java线程与操作系统 ...

  9. Python的json操作

    对数据:    json = json.dumps(data)  编码  dict->string  排序sort_keys=True, 缩进indent=4, 分隔符separators=(' ...

  10. vagrant root 登录虚拟机

    这个问题本来觉得是个特别简单的问题,昨天弄的时候折腾了半晚上.所以打算记录下过程,主要也被网上的各种信息误导了. 1 先看下我这vagrant配置信息 Vagrant.configure(" ...