与类有关的几个函数
1、getattrr():获取对象的属性和方法
getattr有三个参数:getattr(对象名或类名,属性,‘default’)
最后一个default是默认值,也就是某个类或者某个对象没有你要获取的属性或者方法时,返回default
2、setattrr():设置一个不存在的属性
setattr(对象名或类名,属性名,设置的值)
使用setattr时有两种情况:
第一种就是原本对象或者类内并没有这个属性,我可以通过setattr来进行添加并赋值
第二种就是,假如某对象或者类内已经存在某属性,再用setattr进行操作的话就相当于对该属性值进行修改
3、hasattrr():判断对象有没有某属性或者方法,返回布尔值
hasattr(对象或类名,要检查的属性名或方法名)
4、delattrr():删除属性
类属性只能通过类名来删
5、isinstancer():检查是不是这个对象产生的实例,返回布尔值
6、issubclassr():检查一个类是否是另一个类的子类,返回布尔值
7、dir() : 获取对象的成员列表
die(类)和dir(实例对象)输出一致
8、property() ------使用在类的内部处理set和get方法
property() 函数的作用是在新式类中返回属性值。
class property([fget[, fset[, fdel[, doc]]]])
- fget -- 获取属性值的函数
- fset -- 设置属性值的函数
- fdel -- 删除属性值函数
- doc -- 属性描述信息
对应实现了自己的get_attr 和set_attr或del_attr方法的属性, 如果想要替换成新式类的用法, 而不影响之前类的调用逻辑, 可以使用property绑定其get,set,del方法, 从而在正常的 点(.)访问和修改操作时能够正常映射到这些方法。
#使用property绑定fee 的get_fee和set_fee方法
fee = property(get_fee, set_fee)
除了使用property将get, Set方法映射到对属性的访问上, python还推荐使用@property来处理get和set方法。
class Student():
def __init__(self,name,age):
self.__name=name
self.__age=age
@property
def age(self):
print('reading age')
return self.__age
@age.setter
def age(self, age):
print('setting age')
self.__age = age
@age.deleter
def age(self):
print('deleting age')
del self.__age
类内置属性
1、__name__
文档,也就是获取类的名称
2、__doc__
文档,也就是获取类的注释文档
注意它只返回第一个三对单引号或三对双引号的类的注释文档。
3、__dict__
:
dict是用来存储对象属性的一个字典,其键为属性名,值为属性的值。
许多内建类型就没有__dict__
属性,如list,此时就需要用dir()来列出对象的所有属性。
- 类的dict存储所有实例共享的变量和函数(
类属性,方法等
),类的dict并不包含其父类的属性。 - 实例的dict仅存储与该实例相关的实例属性('不包含类属性'),正是因为实例的dict属性,每个实例的实例属性才会互不影响。
4、__bases__
:
可知道这个类的父类是谁
类魔术方法
一、操作相关
1、__init__ ()
初始化函数(构造函数)
Python的类中可以有很多个构造函数,但是最后一个构造函数会覆盖掉上面的构造函数,所以,只有最后一个init函数有效, 可以通过定义类方法实现多个构造方法的技巧。
2、__call__()
对象当函数使用时触发
实例化对象()自动调用类中的__call__
方法

第一个参数为当前类对象self
def __call__(self, *args, **kwargs):
...
3、__str__ ()
和 __repr__()
__str__ ()
在对象当字符串使用时触发,返回一个很好地向人描述对象的字符串。
__repr__()
在对象当字符串使用时触发,返回供解释器读取的字符串,一般是返回类名。
使用str()或repr()方法来解析对象时, 就会触发对象的str和repr方法。
如果实现了repr而没有定义str,那么对象将会表现出str = repr
4、__new__()
--重要
特性:
-
__new__
方法是在类准备将自身实例化时调用。 -
__new__
方法始终都是类的静态方法,即使没有被加上静态方法装饰器
在定义新式类时没有重新定义new()时,Python默认是调用该类的直接父类的new()方法来构造该类的实例,如果该类的父类也没有重写new(),那么将一直按此规矩追溯至object的new()方法,因为object是所有新式类的基类。
新式类开始实例化时,new()方法会返回cls(cls指代当前类)的实例,然后该类的init()方法作为构造方法会接收这个实例(即self)作为自己的第一个参数,然后依次传入new()方法中接收的位置参数和命名参数。
注意:如果new()没有返回cls(即当前类)的实例,那么当前类的init()方法是不会被调用的。如果new()返回其他类(新式类或经典类均可)的实例,那么只会调用被返回的那个类的构造方法。
第一个参数cls是当前正在实例化的类
def __new__(cls, *args, **kwargs):
...
return object.__new__(cls)
二、描述符相关
如果一个对象定义了这三种方法的任何一种,它就是一个描述符(descriptor)。
描述符详解参考我另一篇文章
1、__get__
获取属性时调用,返回设置的属性值,通常是set中的value,或者附加的其他组合值。
2、__set__
设置属性时调用,返回None.
3、__delete__
删除属性时调用,返回None
二、属性操作和访问相关
1、__getattr__
访问属性不存在时调用改方法
2、__setattr__
修改属性不存在时调用改方法
3、__getattribute__
不需要自行定义,除非对属性访问有特殊的要求
对新式类的实例来说,所有属性和方法的访问操作都是通过getattribute完成,这是由object基类实现的。如果有特殊的要求,可以重载getattribute方法。
每次通过实例访问属性,都会经过getattribute函数。而当属性不存在时,仍然需要访问getattribute,不过接着要访问getattr。这就好像是一个异常处理函数。
与__getattribute__
有关 的属性搜索策略参考
网友评论