Python进阶之面向对象(类的特殊方法)

1. 与类有关的几个函数

hasattr()       #判断对象object是否包含名为name的特性
getattr()		# 得到对象的某个属性值 (获取器)
setattr()		# 给对象添加某个属性值 (设置器 ),(实例调用,只对当前实例有用),类调用,对所有实例有用
delattr()		# 删除对象属性 (删除器)
isinstance()  	# 检查对象是否是类的对象,返回True或False
issubclass()  	# 检查一个类是否是另一个类的子类。返回True或False
复制代码

代码示例:

class A():
    name=1
    def test(self):
        raise IOError("错误")
print(hasattr(A,"nam")) #False
print(getattr(A,"name")) #1
setattr(A,"name","xfy")
print(getattr(A,"name")) #xfy
delattr(A,"name")
setattr(A,"name","xfy")
print(getattr(A,"name"))#xfy
print(hasattr(A,"test"))#True
print(getattr(A,"test")) #<function A.test at 0x000001D270FDBC80>
a=A()
print(isinstance(a,A)) #True
复制代码

注:

  • setattr:实例调用,只对当前实例有用,类调用,对所有实例有用。
  • delattr方法只能传类,不能传实例
  • hasattr传入类就是查看该类是否有某属性,传实例是查看实例对应的该类是否有某属性。(所以就是无论怎样都是查看类),在python类的定义中方法也是一种特殊的属性。

再看示例:

a.name=12  # 并不会修改类的name
print(a.name) #12
print(A.name)#1
复制代码

实例修改类变量只是改了自己当前范围的值,并不能改变累的属性。

2. 类的特殊方法

#类属性:
    __dict__ 	# 类的属性(包含一个字典,由类的数据属性组成)
    __doc__ 	# 类的文档字符串
#类方法:  
    __init__    # 初始化
    __repr__    # 直接返回这个对象  repr() 函数就是调用对象的这个方法
    __str__     # print(obj) 如果类里面定义了__repr__,没有定义__str__   print(obj)也会返回__repr__的内容,或者说__repr__的优先级更高
    __call__    # Obj() 使实例可被调用
    
#运算符方法
    __add__(self,other)     #x+y
    __sub__(self,other)     #x-y 
    __mul__(self,other)     #x*y  
    __mod__(self,other)     #x%y
    __iadd__(self,other)    #x+=y
    __isub__(self,other)    #x-=y 
    __radd__(self,other)    #y+x
    __rsub__(self,other)    #y-x 
    __imul__(self,other)    #x*=y 
    __imod__(self,other)    #x%=y  不v
复制代码

示例:

class B():
    '''
    这是一个测试用的类
    '''
    def __init__(self,name,age):
        self.name=name
        self.age=age
    def __str__(self):
        return "这是一个B类"
    def __call__(self, *args, **kwargs):
        return self.name

b=B("xfy",20)
print(B.__doc__)#这是一个测试用的类
print(b.__dict__)#{'name': 'xfy', 'age': 20}
print(b)#这是一个B类
print(b.__repr__())#<__main__.B object at 0x000001AC26405F28>
print(b.__str__())#这是一个B类
print(b())#xfy
复制代码

注: __repr__和__str__的区别

__repr__是给程序员和机器看的。

__str__可重写给用户看了。

实现两个实例像数字一样相加

示例:

#为什么1+2,但是b+c不行
#我们来看dir(1)
print(dir(1))#['__abs__', '__add__', '__and__', '__bool__', '__ceil__', '__class__', '__delattr__', '__dir__', '__divmod__', '__doc__', '__eq__', '__float__', '__floor__', '__floordiv__', '__format__', '__ge__', '__getattribute__', '__getnewargs__', '__gt__', '__hash__', '__index__', '__init__', '__init_subclass__', '__int__', '__invert__', '__le__', '__lshift__', '__lt__', '__mod__', '__mul__', '__ne__', '__neg__', '__new__', '__or__', '__pos__', '__pow__', '__radd__', '__rand__', '__rdivmod__', '__reduce__', '__reduce_ex__', '__repr__', '__rfloordiv__', '__rlshift__', '__rmod__', '__rmul__', '__ror__', '__round__', '__rpow__', '__rrshift__', '__rshift__', '__rsub__', '__rtruediv__', '__rxor__', '__setattr__', '__sizeof__', '__str__', '__sub__', '__subclasshook__', '__truediv__', '__trunc__', '__xor__', 'bit_length', 'conjugate', 'denominator', 'from_bytes', 'imag', 'numerator', 'real', 'to_bytes']
#1有一个__add__接口,如果我们也能在B里实现这个__add__,不也能跟随我们的意愿做数学操作了吗?
class B():
    def __init__(self,name,age):
        self.name=name
        self.age=age
    def __add__(self, other):
        return self.age+other.age
b=B("xfy",20)
c=B("stefan",21)
print(b+c)#41,b+c是两个人年龄的和
复制代码

所以只要我们在类里加了相应的接口就能一些特殊的功能。

转载于:https://juejin.im/post/5add8aed6fb9a07aa212f43b

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值