isinstance(obj,cls)和issubclass(sub,super)

isinstance(obj,cls)检查是否obj是否是类 cls 的对象,如果是返回True

1 class Foo(object):
2 pass
3 obj = Foo()
4 print(isinstance(obj, Foo))

issubclass(sub, super)检查sub类是否是 super 类的派生类,如果是返回True

1 class Foo(object):
2 pass
3 class Bar(Foo):
4 pass
5 issubclass(Bar, Foo)

反射

反射主要是指程序可以访问、检测和修改它本身状态或行为的一种能力(自省)。

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

示例代码:

1 class Teacher:
2 school='jialidun'
3 def __init__(self,name,age):
4 self.name=name
5 self.age=age
6 def teach(self):
7 print('%s teach' %self.name)

通过字符串的方式判断是否存在一个属性:

1 t=Teacher('bob',18)
2 print(hasattr(Teacher,'name')) #False
3 print(hasattr(Teacher,'school')) #True
4 print(hasattr(Teacher,'teach')) #True
5 print(hasattr(t,'name')) #True
6 print(hasattr(t,'school')) #True
7 print(hasattr(t,'teach')) #True

通过字符串的方式获取一个属性:

1 print(getattr(Teacher,'school'))    #获取到则返回属性的值
2 print(getattr(Teacher,'sdfad',None)) #获取不到返回None,如果不指定None那么抛出异常错误

通过字符串的方式设定一个属性:

1 setattr(Teacher,'sex','male')    #设定Teacher类的属性sex='male'
2 setattr(t,'sex','female') #设定对象t对象的属性sex='female'
3 print(Teacher.__dict__)
4 print(t.__dict__)

通过字符串的方式删除一个属性:

1 delattr(Teacher,'sex')
2 delattr(t,'sex')

反射应用场景:用户交互

 1 class Cmd:
2 def __init__(self,name):
3 self.name=name
4 def run(self):
5 while True:
6 cmd=input('>>>').strip()
7 if not cmd:continue
8 if hasattr(self,cmd): #判断这个类包含不包含输入的属性
9 func=getattr(self,cmd) #如果包含,获取该属性
10 func() #执行该属性(输入name会抛错提示字符串不能被调用,因为name是一个数据属性,而非函数属性)
11 else:
12 print('not valid func')
13 def ls(self):
14 print('ls function')
15 def pwd(self):
16 print('pwd function')
17 def cat(self):
18 print('cat function')
19 c=Cmd('bob')
20 c.run()

反射的好处

实现可插拔机制:可以事先定义好接口,接口只有在被完成后才会真正执行,这实现了即插即用,这其实是一种‘后期绑定’,即可以事先把主要的逻辑写好(只定义接口),然后后期再去实现接口的功能

动态导入模块:基于反射当前模块成员

__str__方法

改变对象的字符串显示

 1 class Teacher:
2 def __init__(self,name,age):
3 self.name=name
4 self.age=age
5 t=Teacher('bob',18)
6 print(t)
7 输出结果
8 <__main__.Teacher object at 0x0000020FC4DA9278>
9
10 #########分割线君###########
11
12 class Teacher:
13 def __init__(self,name,age):
14 self.name=name
15 self.age=age
16 def __str__(self):
17 return '<name:%s age:%s>' % (self.name, self.age)
18 t=Teacher('bob',18)
19 print(t) #t.__str__()
20 输出结果:类中的__str__函数的执行结果
21 <name:bob age:18>

__del__方法

在程序执行完了之后会自动执行的内容

 1 class Foo:
2 def __init__(self,x):
3 self.x=x
4 def __del__(self):
5 print('执行__del__')
6 '''一般用来做一些关于对象执行完了之后剩下的垃圾的清理操作'''
7 f=Foo(10)
8 print('执行完了')
9
10 输出结果:先执行最后的print,没有代码了执行__del__函数
11 执行完了
12 执行__del__

删除对象后立即执行的内容

 1 class Foo:
2 def __init__(self,x):
3 self.x=x
4 def __del__(self):
5 print('执行__del__')
6 '''做一些关于对象的清理操作'''
7 f=Foo(10)
8 del f #删除的时候也会执行del内容
9 print('执行完了')
10
11 输出结果:删除了f对象后执行了__del__后才执行最后的print
12 执行__del__
13 执行完了

item系列

以中括号的方式进行处理类似于:

1 l=['a','b','c']
2 dic={'a':1}
3 print(l[1])
4 print(dic['a'])

__getitem__、__setitem__、__delitem__

 1 class Teacher:
2 def __init__(self,name,age,sex):
3 self.name=name
4 self.age=age
5 self.sex=sex
6 def __getitem__(self, item): #查询
7 # return getattr(self,item)
8 return self.__dict__[item]
9 def __setitem__(self, key, value): #设置
10 # setattr(self,key,value)
11 self.__dict__[key]=value
12 def __delitem__(self, key): #删除
13 # delattr(self,key)
14 self.__dict__.pop(key)
15 f=Teacher('bob',18,'male')
16 print(f.name) #f['name']
17 print(f['name']) #查询
18 f['name']='bob_nb' #设置
19 print(f.__dict__)
20 del f['name'] #删除
21 print(f.__dict__)

__len__方法

给对象提供len()统计方法

1 class Teacher:
2 def __init__(self,name,age,sex):
3 self.name=name
4 self.age=age
5 self.sex=sex
6 def __len__(self): #长度设置为10
7 return 10
8 f=Teacher('bob',18,'male')
9 print(len(f)) #输出10

其他方法(补充)

__setattr__,__delattr__,__getattr__方法

 1 class Foo:
2 x=1
3 def __init__(self,y):
4 self.y=y
5 def __getattr__(self, item):
6 print('----> from getattr:你找的属性不存在')
7 def __setattr__(self, key, value): #限制赋值,无法对属性直接赋值,必须要对__dict__进行操作赋值
8 print('----> from setattr')
9 # self.key=value #这就无限递归了,任何赋值操作都会调用__setattr__的运行,所以....
10 # self.__dict__[key]=value #应该使用这种方式,操作字典可以赋值成功
11 def __delattr__(self, item):
12 print('----> from delattr')
13 # del self.item #无限递归了,同__setattr__方法的无限递归
14 self.__dict__.pop(item)
15 #__setattr__添加/修改属性会触发它的执行
16 f1=Foo(10)
17 f1.__setattr__('a',1) #不是直接操作字典,无法赋值
18 print(f1.__dict__) # 因为重写了__setattr__,凡是赋值操作都会触发它的运行,什么都不写,就是根本没赋值,除非直接操作属性字典,否则永远无法赋值
19 f1.z=3
20 print(f1.__dict__)
21 #__delattr__删除属性的时候会触发
22 f1.__dict__['a']=3#我们可以直接修改属性字典,来完成添加/修改属性的操作
23 del f1.a #删除的时候如果上面函数是del self.item,会无限递归
24 print(f1.__dict__)
25
26 #__getattr__只有在使用点调用属性且属性不存在的时候才会触发
27 f1.xxxxxx

包装(对标准数据类型进行方法修改)

通过继承和派生的方式,进行修改源生数据类型的方法

 1 class List(list): #继承list所有的属性,也可以派生出自己新的,比如append和mid
2 def append(self, p_object):
3 '派生自己的append:加上类型检查'
4 if not isinstance(p_object,int):
5 raise TypeError('must be int')
6 super().append(p_object)
7 @property
8 def mid(self):
9 '新增自己的属性'
10 index=len(self)//2
11 return self[index]

Day 22 Object_oriented_programming 3的更多相关文章

  1. CENTOS 6.5 平台离线编译安装 Mysql5.6.22

    一.下载源码包 http://cdn.mysql.com/archives/mysql-5.6/mysql-5.6.22.tar.gz 二.准备工作 卸载之前本机自带的MYSQL 安装 cmake,编 ...

  2. EC笔记:第4部分:22、所有成员都应该是private的

    EC笔记:第4部分:22.所有成员都应该是private的 更简单的访问 用户不用记得什么时候该带上括号,什么时候不用带上括号(因为很确定的就要带上括号) 访问限制 对于public的成员变量,我们可 ...

  3. Hadoop学习笔记—22.Hadoop2.x环境搭建与配置

    自从2015年花了2个多月时间把Hadoop1.x的学习教程学习了一遍,对Hadoop这个神奇的小象有了一个初步的了解,还对每次学习的内容进行了总结,也形成了我的一个博文系列<Hadoop学习笔 ...

  4. 在同一个硬盘上安装多个 Linux 发行版及 Fedora 21 、Fedora 22 初体验

    在同一个硬盘上安装多个 Linux 发行版 以前对多个 Linux 发行版的折腾主要是在虚拟机上完成.我的桌面电脑性能比较强大,玩玩虚拟机没啥问题,但是笔记本电脑就不行了.要在我的笔记本电脑上折腾多个 ...

  5. Fedora 22中的Services and Daemons

    Introduction Maintaining security on your system is extremely important, and one approach for this t ...

  6. Fedora 22中的RPM软件包管理工具

    Introduction The RPM Package Manager (RPM) is an open packaging system that runs on Fedora as well a ...

  7. Fedora 22中的用户和用户组管理

    The control of users and groups is a core element of Fedora system administration. This chapter expl ...

  8. Fedora 22中的日期和时间配置

    Introduction Modern operating systems distinguish between the following two types of clocks: A real- ...

  9. Fedora 22中的DNF软件包管理工具

    Introduction DNF is the The Fedora Project package manager that is able to query for information abo ...

随机推荐

  1. LeetCode#453 最小移动次数使数组元素相等

    给定一个长度为 n 的非空整数数组,找到让数组所有元素相等的最小移动次数.每次移动可以使 n - 1 个元素增加 1. 示例: 输入: [,,] 输出: 解释: 只需要3次移动(注意每次移动会增加两个 ...

  2. python练手习题

    不断记录python常见习题,不断寻求更多更好的解决办法.持续更新中..... 练习: 1. list两两元素交换位置,如[1,2,3,4,5,6] 执行后为 -> [2,1,4,3,6,5] ...

  3. scrapy框架简介和基础使用

    概念 为了爬取网站数据而编写的一款应用框架,出名,强大.所谓的框架其实就是一个集成了相应的功能且具有很强通用性的项目模板.(高性能的异步下载,解析,持久化……) 安装 linux mac os:pip ...

  4. poj 3258 跳房子问题 最大化最小值

    题意:奶牛跳房子,从n块石头中移除M块,使得间距最小的最大值?思路:“转换” 从N块中选择n-m块使得两两之间的间距尽可能大 c(d) 是间距最大的满足条件,即第一块 放在 xi的位置 下一块就要放在 ...

  5. Android拨打电话不弹出系统拨号界面总结

    我在网上搜了一下,解决这个问题,有两种方式: 1.反射调用系统底层方法,并获取系统权限 反射调用的代码如下: Class phoneFactoryClass = Class.forName(" ...

  6. java十分钟速懂知识点——引用

    一.由健忘症引起的问题 今天闲来没事在日志中瞟见了个OutOfMemoryError错误,不由得想到前一段时间看到一篇面经里问到Java中是否有内存泄露,这个很久以前是留意过的,大体记得内存溢出和内存 ...

  7. 平衡树 - Luogu 1486 郁闷的出纳员

    这么久没写平衡树了,再来一发... P1486 郁闷的出纳员 题目描述 OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的 ...

  8. OpenStack之各组件介绍

    OpenStack简介 OpenStack既是一个社区,也是一个项目和一个开源软件,它提供了一个部署云的操作平台或工具集.其宗旨在于:帮助组织运行为虚拟计算或存储服务的云,为公有云.私有云,也为大云. ...

  9. CSU-2019 Fleecing the Raffle

    CSU-2019 Fleecing the Raffle Description A tremendously exciting raffle is being held, with some tre ...

  10. 观数据世界,览类型风骚---Python

    一.变量的简介 变量只不过是保留的内存位置用来存储数据.这意味着,当创建一个变量,那么它在内存中保留一些空间. 根据一个变量的数据类型,解释器分配内存,并决定如何可以被存储在所保留的内存中.因此,通过 ...