Python魔术方法专题
作者:BlackMonkey 发布时间:2023-03-14 15:38:02
_del_
类的析构方法,它在对象被回收时执行,主要的作用时用来释放资源(内存 文件 进程等)
因为Python内存回收机制,使得Python的del方法的执行时间是不确定的,因此不推荐在Python中使用析构方法。
class Bar(object):
def __del__(self):
print("被回收了! ~")
a = Bar()
a.__del__() # 主动调用是没用的,因为引用计数不为零,并不会回收资源 gc
print("已经删除a了")
print(a)
del a
# print(a)
_dict_
是一个绑定对象属性的字典 存储的是属性的 键值对应关系
可以直接通过修改这个字典来为对象添加属性(但是不推荐这样做!会使得程序的可读性降低 破坏程序的结构 充分理解 后使用 但是也要慎重)甚至 你可以通过修改 dict 来为对象添加方法 例如 func
_slots_
限定类的对象只能拥有某些属性,防止写错属性名,也可以实现不允许动态添加其他属性。
形式:一个元组或 列表
需要注意 一旦类指定了 slots 那就意味着 类的属性键值绑定关系 由__slots__来维护 也就是说 对象将没有 __dict__方法
__slots__只能约束本类,不能约束继承它的子类,如果子类也定义了slots 方法,那么对子类的约束将会成为两者的并集。
class Bar(object):
__slots__ = ('name', 'gender')
def __init__(self, name='monkey'):
self.name = name
self.gender = 'male'
a = Bar()
a.age = 18 # 动态添加属性是会报错的。
print(a.name)
_str_
必须返回一个str 类型 在打印对象的时候将会 打印返回的 str 而不是默认的 self.str
:return: <main.... object at 0x1084b7208>
class Bar(object):
def __str__(self):
return "Bar"
a = Bar()
print(a) # Bar
_repr_
将对象转化成对解释器友好的形式,它跟eval()方法联系紧密,通常repr()调用 对象的__repr__方法,该方法返回以字符串格式的 对解释器友好的 对象描述,eval() 可以将repr()的返回值 转化为原对象。
这玩意很强大,它是最直接的多态体现,几乎任何类对象都实现了它,但是每个返回的结果都是不一样的。
_class_
_class_ 允许通过对象调用类的方法和操作类的属性即 object.__class__ 可以拿到这个对象的类
拿到类后可以进行新的实例化 操作类的属性 调用类的方法等.
class Bar(object):
name = 'monkey'
a = Bar()
print(a.__class__.name) # 允许通过实例化对象访问类
_doc_
打印对象或类或方法的文档字符串
class Bar(object):
"""
A simple show class!
"""
name = 'monkey'
def get_name(self):
"""
get class argument name
"""
return self.__class__.name
a = Bar()
print(a.__class__.__doc__)
print(a.__class__.get_name.__doc__)
# A simple show class!
#
#
# get class argument name
_base_
用来返回类的父类
_bases_
用来返回类的继承列表
class Lady(object):
""" """
class Small(object):
""" """
class SmallLady(Small, Lady):
""""""
print(Lady.__base__) # <class 'object'>
print(SmallLady.__bases__) # (<class '__main__.Small'>, <class '__main__.Lady'>)
_iter_
必须返回可迭代对象
这个对象需要实现__next__方法。
_next_
每次返回迭代器的下一个值或一个迭代异常来终止迭代。
_len_
每次返回迭代器的下一个值或一个迭代异常来终止迭代。
class ListMeta(type):
def __call__(self, data, *args, **kwargs): # 使得self 也就是实例化出的类 是可调用的 List() 这里的self指的是 将要 实例化出来的类 本身
self.__init__(self,data)
return self
def __str__(self):
result = self.clean_data(self) # 是 List 可以返回期望的列表格式 将对象转化为对人友好的字符串
result = '[{}]'.format(result[:-1])
return result
def __repr__(self):
return 'List({})'.format(self.__str__()) # 转化为对解释器友好的字符串
def __iter__(self):# 返回实现了迭代器协议的对象
return self # 它本身实现了 __next__
def __next__(self):# 实现迭代器协议,每次返回下一个值 或 一个迭代异常终止迭代
if self.index >= len(self.data):
raise StopIteration
else:
value = self.data[self.index]
self.index += 1
return value
def __len__(self): # 返回对象的长度,len()函数会执行对象的 __len__方法
return self.len
class List(metaclass=ListMeta):
def __init__(self, data):
self.data = data
self.index = 0
self.len = len(self.data)
l = List([1,2,3,4,5,6,7])
print(l)
print(len(l))
for i in l:
print(i)
_hash_
必须返回一个int类型的数据,并且可以唯一的表示这个对象。这点很重要。
_getattribute_
此方法在每次访问对象的属性之前都会被调用,它容易使你陷入无限的递归中。
如果需要对对象属性的访问做一些限制 譬如 以"block_" 开头的属性不允许访问可以这样来实现,这时候她是非常有用的。
如果该方法找到了对象的属性,那么直接返回其属性值,如果找不到或报错了,无论如何没有达到预期的结果,那就调用 _getattr_ 方法。
_getattr_
当以 点 属性名的形式访问属性时,如果属性不存在,则会执行对象的 _getattr_ 方法 该方法接受一个变量,item,即访问的属性名。返回值为本次获取的属性值,但是这个值并没有写入 对象的属性字典里。
也就是说如果属性在__getattribute__中找到是不会执行这个方法的。
这个方法也容易陷入无限的递归当中。
_setattr_
以点属性名的形式设置属性时,会调用 _setattr_ 方法,此方法需要将属性名和属性值的对应关系写入关系字典__dict__里。如果重写了该方法,一定不要忘记手动的更新 对象属性字典。
class Storage(object):
def __init__(self, name):
self.name = name # 调用__setattr__方法
def __getattribute__(self, item): # 每个属性访问前都先调用该方法
print('getattribute: %s' % item)
ret = True
if item == 'error':
raise AttributeError(r'Error ~ "error"') # 报错了依然执行~
else:
ret = object.__getattribute__(self, item)
return ret
def __getattr__(self, item):
print('getattr: %s' % item)
try:
return self.__dict__[item]
except (IndexError, KeyError)as e:
print('No attribute %s ' % e)
return '%s is error' % item
def __setattr__(self, key, value):
print('setattr: %s ' % key)
self.__dict__.update({key:value})
file = Storage('file')
name = file.error # 调用 __getattr__ 方法
# setattr: name
# getattribute: __dict__
# getattribute: error
# getattr: error
# getattribute: __dict__
# No attribute 'error'
来源:https://www.cnblogs.com/monkey-code/p/13160624.html


猜你喜欢
- 方法一:import osimport cv2 as cvimport numpy as np# 读取yuv420p的一帧文件,并转化为pn
- 通用用法但上图的字段名,类型需要根据不同接口填写,如某服务接口:因而对应的上传代码如下:# 输出参数:请求响应报文import reques
- 数据库中内置函数的使用该篇主要介绍数据库中内置函数的使用,主要有日期函数,字符串函数,数学函数。(一)日期函数select current_
- arguments.callee关于callee的解释:callee 是 arguments 对象的一个属性。可以用于引用该函数的函数体内当
- 我就废话不多说了,大家还是直接看代码吧~lt=client.fangjia.district_stat_all_0416dl = dt.fi
- 示意图:html:(模态框等 html和js代码,参考:Django 创建/删除用户){# 权限管理 #} <div id
- 本文实例为大家分享了python爬取淘宝商品的具体代码,供大家参考,具体内容如下import requests as req import
- 简单说明这个算法主要工作是测量不同特征值之间的距离,有个这个距离,就可以进行分类了。简称kNN。已知:训练集,以及每个训练集的标签。接下来:
- 需求小编通常会上一些专业的视频网站比如腾讯视频、优酷,在上面看电影、电视剧。这些网站有个优点,可以缓存视频,在通勤路上比如地铁就可以愉快的刷
- 代码如下import numpy as npfrom matplotlib import pyplot as plt# 用numpy生成数据
- while循环是PHP中最简单的循环,其基本格式为:while (expr){ statement } 或者while (ex
- 本文实例讲述了Python使用win32com实现的模拟浏览器功能。分享给大家供大家参考,具体如下:# -*- coding:UTF-8 -
- 升级背景:为了解决mysql低版本的漏洞,从mysql5.5升级到了8.0.11版本,再次升级到了8.0.17版本(从版本是2019.7.2
- 本文假设某些特定类型的文件和大小为0的文件为垃圾文件,可以自由扩展代码的列表,也就是垃圾文件的类型。from os.path import
- 很多网站需要将好的会员号留着,或用于日后的盈利。实现方法不是本文讨论范围,本文仅列出用于检测靓号类型的一些正则。靓号检测:主要可以检测连号(
- 本文实例为大家分享了js选项卡切换的具体代码,可以手动切换,另设置定时器可使其自动切换,供大家参考,具体内容如下效果如图:具体代码:<
- 根本原因:python定义函数时,一般都会有指定返回值,如果没有显式指定返回值,那么python就会默认返回值为None我们输入的代码如下:
- 前言:在搭建开始前,我们先来梳理下web服务工作流程,先看下图:1、用户(PC)向web服务器发起http请求2、web服务器判断用户请求文
- 在windows10系统下安装两个不同版本的的python解释器,在通常情况下编译执行文件都是没问题的,但是加载或下载包的时候pip的使用就
- 作者:catmelo 本文版权归作者所有链接:https://www.cnblogs.com/catmelo/p/4162101.html本