目录

1.__del__(析构方法)

2.魔术方法:__str__

3.魔术方法:__repr__

4.魔术方法:__call__

5.魔术方法:__bool__

6.魔术方法:__add__&__radd__

7.魔术方法:__len__

8.与类相关的魔术属性

一个小表格方便记忆哈

__del__ (析构方法)

__del__简要介绍

1.触发时机:当对象被内存回收的时候自动触发

  (1)页面执行完毕回收所有变量

  (2)所有对象被del的时候

2.功能:对象使用完毕后资源回收

3.参数:一个self接受对象

4.返回值:

第一种情况:页面执行完毕回收所有变量

class LangDog():
food = "改吃蔬菜" def __init__(self, name):
self.name = name def __del__(self):
print("析构方法被触发")
print("0001=====")
obj = LangDog("肉丝")
print("0002=====")
# 1.页面执行完毕回收所有变量
print(obj.name) # 当执行完这句话后,才算页面执行完毕,这个时候触发__del__析构方法 '''
运行结果:
=====
=====
肉丝
析构方法被触发
'''

第二种情况:所有对象被del的时候

如何理解第二种情况中所说到的所有对象?

代码如下:

class LangDog():
food = "改吃蔬菜" def __init__(self, name):
self.name = name def __del__(self):
print("析构方法被触发") obj1 = LangDog("肉丝")
obj2 = obj1
print("<=====start=====>")
del obj1
print("<=====end=====>")

打印结果:

虽然obj1对象被删除了,但是obj2对象并没有被删除,所以不会触发析构方法

打印了“析构方法被触发”是因为整个页面执行完毕了,也会触发析构方法

使用__del__模拟文件操作

# 3.模拟文件操作
import os
class ReadFile():
def __new__(cls,filename):
if os.path.exists(filename): # 判断文件路径是否存在
return object.__new__(cls) # 如果文件存在,创建文件对象
else:
return print("该文件是不存在的") # 如果文件不存在,给予错误提示 def __init__(self,filename):
# 打开文件
self.fp = open(filename,mode="r+",encoding="utf-8") def readcontent(self):
# 读取文件
return self.fp.read() def __del__(self):
# 关闭文件
self.fp.close() obj = ReadFile("1.txt") if obj is not None:
res = obj.readcontent()
print(res)
else:
print("没有该类文件") # 当然,也可以用三元运算符来实现
""" 真值 if 条件表达式 else 假值 """
print(obj.readcontent()) if obj is not None else print("没有该类文件")

魔术方法:__str__

__str__简要介绍

1.触发时机: 使用print(对象)或者str(对象)的时候触发

2.功能: 查看对象

3.参数: 一个self接受当前对象

4.返回值: 必须返回字符串类型

class Cat():
gift = "小猫咪会卖萌求猫粮,小猫咪抓老鼠"
def __init__(self,name):
self.name = name def __str__(self):
return self.cat_info() def cat_info(self):
return "小猫咪的名字是{},小猫咪{}元".format(self.name,5000) # __repr__ = __str__ tom = Cat("汤姆")
# 方法一. print(对象)
print(tom)
# 方法二. str(对象)
res = str(tom)
print(res)

魔术方法:__repr__

1.触发时机: 使用repr(对象)的时候触发

2.功能: 查看对象,与魔术方法__str__相似

3.参数: 一个self接受当前对象

4.返回值: 必须返回字符串类型

class Mouse():
gift = "偷粮食"
def __init__(self,name):
self.name = name def __repr__(self):
return self.mouse_info() def mouse_info(self):
return "名字是{},龙生龙,凤生凤,老鼠的儿子会打洞,还会{}".format(self.name,self.gift) # 系统在底层,自动加了一句赋值操作
__str__ = __repr__ jerry = Mouse("杰瑞")
res = repr(jerry)
print(res) # 因为系统底层赋值的原因,在打印对象或者强转对象为字符串的时候,仍然可以触发;
print(jerry)
res = str(jerry)
print(res)

魔术方法:__call__

1.触发时机:把对象当作函数调用的时候自动触发

2.功能: 模拟函数化操作

3.参数: 参数不固定,至少一个self参数

4.返回值: 看需求

基本用法

# (1) 基本用法
class MyClass():
a = 1
def __call__(self):
print("call魔术方法被触发了") obj = MyClass() # 实例化一个对象
obj() # 把对象当做函数调用,此时会触发__call__方法

模拟洗衣服的过程

# (2) 模拟洗衣服的过程
class Wash(): def __call__(self,something):
print("我现在要洗{}".format(something))
self.step1()
self.step2()
self.step3()
return "洗完了" def step1(self):
print("加热水,家洗衣粉,加洗衣液,加洗涤剂") def step2(self):
print("衣服泡进去搅乱 打散 搓一搓~ ") def step3(self):
print("脱水,穿上") obj = Wash() # 方法一
# obj.step1()
# obj.step2()
# obj.step3() # 方法二
res = obj("衣服") # 把对象obj当做函数进行调用,此时触发__call__方法,执行__call__方法所有内容
print(res)

模拟内置的int方法,实现相应的操作(有时间再分析)

# (3) 模拟内置int 实现相应的操作
import math
class MyInt(): def calc(self,num,sign=1):
# print(num,sign) # 去掉左边多余的0
strvar = num.lstrip("0")
# print(strvar) # 为了防止都是0 ,如果去掉之后为空,返回0
if strvar == "":
return 0 # 正常情况下,执行存数字字符串变成数字 , 在乘上相应的符号,得出最后的结果
return eval(strvar) * sign def __call__(self,num):
if isinstance(num , bool):
if num == True:
return 1
elif num == False:
return 0 elif isinstance(num,int):
return num elif isinstance(num,float):
# 方法一
"""
strvar = str(num)
lst = strvar.split(".")
return eval(lst[0])
"""
# 方法二
"""
if num >= 0:
return math.floor(num)
else:
return math.ceil(num)
"""
return math.floor(num) if num >= 0 else math.ceil(num) elif isinstance(num,str):
if (num[0] == "+" or num[0]== "-") and num[1:].isdecimal():
if num[0] == "+":
sign = 1
else:
sign = -1 return self.calc(num[1:],sign) elif num.isdecimal():
return self.calc(num)
else:
return "老铁,这个真转不了" myint = MyInt()
# myint(5) => 5
# myint(3.14) => 3 res = myint(True)
print(res)
res = myint(100)
print(res)
res = myint(3333.14)
print(res, type(res)) # 3
# bool int float "12312312323" # int(3.14) => 3
print(int(3.14)) # 3
print(int(-3.14)) # -3
print("<===>")
print(myint(3.14))
print(myint(-0.2)) print("<===>")
print(int("0000000000000000000000000000000000000000001230000000"))
print(int("00000000000000000000000000000000000000000"),"1111222333")
print(int("+000000000000000000000000000000000000000000123"))
print(int("-000000000000000000000000000000000000000000123"))
print(int("000000000000000000000000000000000000000000123")) print("<==111=>")
print(myint("+000000000234"))
print(myint("000000000000000000000000000000000000000000123"))
print(myint("456899200"))
print(myint("3.143434"))
print(myint(+-++-+-+-+-+-+-+-+-+-+-++++++++-----234234),"<====>")
print(int(+-++-+-+-+-+-+-+-+-+-+-++++++++-----234234),"<====>") """
exec("a = 3")
print(a) eval("4")
"""
# print(math.floor(0.14)) # 0
# print(math.floor(3.14)) # 3
# print(math.ceil(-3.14)) # -3

魔术方法:__bool__

__bool__简要介绍

1.触发时机:使用bool(对象)的时候自动触发

2.功能:强转对象

3.参数:一个self接受当前对象

4.返回值:必须是布尔类型

class MyClass():
def __bool__(self):
return False obj = MyClass()
res = bool(obj)
print(res)

类似的还有如下等等(了解):

__complex__(self) 被complex强转对象时调用

__int__(self) 被int强转对象时调用

__float__(self) 被float强转对象时调用

...

...

魔术方法:__add__,__radd__

__add__简要介绍

1.触发时机:使用对象进行运算相加的时候自动触发

2.功能:对象运算

3.参数:二个对象参数

4.返回值:运算后的值

5.注意点:

  对象在加号+的左侧时,自动触发__add__方法

  对象在加号+的右侧时,自动触发__radd__方法

  加号左侧和右侧都是对象时,先触发__add__方法,再触发__radd__方法

class MyClass1():
def __init__(self,num):
self.num = num # 对象在加号+的左侧时,自动触发
def __add__(self,other):
# print(self)
# print(other)
return self.num + other # return 10 + 7 = 17 # 对象在加号+的右侧时,自动触发
def __radd__(self,other):
# print(self)
# print(other)
return self.num * 2 + other # 第一种
a = MyClass1(10)
res = a + 7
print(res) # 第二种
b = MyClass1(5)
res = 20 + b
print(res) # 第三种
print("<============>")
res = a+b
print(res)
"""
第一次触发魔术方法, a+ =>触发__add__方法
self => a other => b
self.num + other => a.num+ b => 10 + b res = 10 + b
第二次触发魔术方法 __radd__
self => b other=> 10
self.num * 2 + other => b.num*2 + other => 5 * 2 + 10 => 20
res = 20
"""

类似的还有如下等等(了解):

__sub__(self, other) 定义减法的行为:-

__mul__(self, other) 定义乘法的行为:*

__truediv__(self, other) 定义真除法的行为:/
...
...

魔术方法:__len__

__len__简要介绍

1.触发时机:使用len(对象)的时候自动触发

2.功能:用于检测对象中或者类中成员的个数

3.参数:一个self接受当前对象

4.返回值:必须返回整型

class MyClass():
pty1 = 1
pty2 = 2
__pty3 = 3
pyt3 =10
pty100 = 90 def func1():
pass def __func2():
pass def __func3():
pass def __len__(self):
lst = []
dic = MyClass.__dict__
# 方法一 # print(MyClass.__dict__) # 获取类当中的所有成员
# print(object.__dict__) # 获取对象中的所有成员
dic = MyClass.__dict__ # 遍历类中所有成员
for i in dic: # 遍历类中所有成员
if not(i.startswith("__") and i.endswith("__")): # 如果开头和结尾都不是以双下划线结尾
lst.append(i) # 将符合条件的成员添加到列表中 return len(lst) # 方法二
lst = [i for i in dic if not(i.startswith("__") and i.endswith("__"))]
return len(lst)

与类相关的魔术属性

__dict__ 获取对象或类的内部成员结构

__doc__ 获取对象或类的内部文档

__name__ 获取类名函数名

__class__ 获取当前对象所属的类

__bases__ 获取一个类直接继承的所有父类,返回元组

class Man():
pass class Woman():
pass class Children(Man,Woman): """
功能: 描述小孩天生的属性
成员属性:eye , skin
成员方法:skylight , moonread , __makebaby
""" eye = "万花筒血轮眼"
skin = "白色" def skylight(self):
print("宇智波家族的小孩,天生能够发动天照技能") def moonread(self,func):
# func = func111
print("宇智波家族的小孩,能够发动月亮的光照消灭你~")
res = func.__name__
print(res,type(res)) def __makebaby(self):
print("这一手招数,只能我自己用") # __dict__ 获取对象或类的内部成员结构
obj = Children()
print(obj.__dict__)
print(Children.__dict__) # __doc__ 获取对象或类的内部文档
print(obj.__doc__)
print(Children.__doc__) # __name__ 获取类名函数名
def func111():
print("我是func111方法")
# 获取函数名
obj.moonread(func111)
# 获取类名
obj.moonread(Man) # __class__ 获取当前对象所属的类
print(obj.__class__) # __bases__ 获取一个类直接继承的所有父类,返回元组
print(Children.__bases__)

day25:7个魔术方法&5个关于类的魔术属性的更多相关文章

  1. Python基础之魔术方法(一个序列容器的魔术方法)

    # 创建自己想要的序列容器魔术方法'''__len__():调用len(obj)函数会调用这个魔术方法__getitem__(self,key):在使用下标操作temp['key']以及切片操作的时候 ...

  2. PHP中的面向对象OOP中的魔术方法

    一.什么是魔术方法: PHP为我们提供了一系列用__开头的函数,这些函数无需自己手动调用,会在合适的时机自动调用,这类函数称为魔术函数.例如: function __construct(){} 在ne ...

  3. day25:魔术方法

    目录 1.__del__(析构方法) 2.魔术方法:__str__ 3.魔术方法:__repr__ 4.魔术方法:__call__ 5.魔术方法:__bool__ 6.魔术方法:__add__& ...

  4. 魔术方法__sleep 和 __wakeup

    感觉序列化和反序列化用得倒是比较少了,而json_encode和json_decode用得相对多,都是转化成串,进行入库.传输等.json更方便,但是序列化和反序列化结合这两个魔术方法使用倒还行< ...

  5. php类自动装载、链式操作、魔术方法

    1.自动装载实例 目录下有3个文件:index.php load.php tests文件夹 tests文件夹里有 test1.php <?php namespace Tests; class T ...

  6. __set()与__get() 魔术方法

    在面向对象编程的过程中,对于类当中的各个成员变量,都有不同的访问属性,比如公有的(public)属性,在类内部和类外部都可直接调用:而私有的(private)和受保护的(protected),在类外不 ...

  7. PHP面向对象中常用的关键字和魔术方法

    PHP面向对象中常用的关键字 final        1.final不能修饰成员属性(类中常量不是用这个关键字)        2.final只能修饰类和方法 作用:            使用fi ...

  8. Python 魔术方法指南

    入门 构造和初始化 构造定制类 用于比较的魔术方法 用于数值处理的魔术方法 表现你的类 控制属性访问 创建定制序列 反射 可以调用的对象 会话管理器 创建描述器对象 持久化对象 总结 附录 介绍 此教 ...

  9. PHP的重载及魔术方法

    首先你要知道什么是php的魔术方法,它不是变魔术的,如果你想学习变魔术来错地方了哦! 定义:PHP 将所有以 __(两个下划线)开头的类方法保留为魔术方法.所以在定义类方法时,除了上述魔术方法,建议不 ...

  10. Python 面向对象(四) 反射及其魔术方法

    反射 reflection 也有人称之为自省 作用: 运行时获取.添加对象的类型定义信息,包括类 内建方法: getattr(object, name[, default])   返回object对象 ...

随机推荐

  1. 12.15linux学习第十八天

    今天老刘讲了如同天书一般的隐藏章节,第23章使用OpenLDAP部署目录服务,难度太高了.第16章使用Squid部署代理缓存服务 章节概述: 本章首先介绍代理服务的原理以及作用,然后介绍Squid服务 ...

  2. 解决git仓库项目 添加到github非空仓库冲突问题 error: failed to push some refs to 'https://github.com/Qtoken/......'

    error: failed to push some refs to 'https://github.com/Qtoken/......' 1. 问题描述:执行命令:git push origin m ...

  3. 8、HTTP Cookie管理器

    如果有需要加的cookie 就选择添加  如果没有特殊的 就默认就好了 第一次访问是没有cookie的 会话  session Cookie 是明文的  Session  id 是保存在cookie里 ...

  4. C# DevExpress gridview 字符串尾部带数字如何排序

    我们经常遇到这样的问题,字符串尾部带数字,如何正确排序; 首先设置GridView ,Columns 的相关列,设置属性中,SortMode为Custom 解决思路,把字符串尾缀数字,分离出来.先比较 ...

  5. Linux 系统下挂载linux 系统盘

    1应用背景:有时候系统崩溃无法修复,无法正常启动,而系统盘里面有需要的文件如log等需要拷贝出来,或者系统盘可以正常启动但是不方便用一台设备来启动这个系统盘.而直接将Linux系统盘接到windows ...

  6. Unity2017-HTC项目串流Pico摇杆移动功能

    最近公司PC项目需要串流到Piconec3上运行,HTC手柄是圆盘键按下移动还可以,但是Piconeo3是摇杆,按下移动的话显得不科学,所以写了一套基于圆盘键,使用摇杆移动的方法 第一步:编写摇杆左右 ...

  7. 痞子衡嵌入式:我当选了2019年度官方论坛i.MXRT板块的顶级贡献者

    痞子衡桌上有一个联邦快递公司件,放了近一个月了,是同事代领的,痞子衡一直没有拆开.今天心血来潮,决定拆开瞧一瞧,这一拆就拆出了一天的好心情. 原来快递里面是一件i.MXRT产品纪念T-shirt,还有 ...

  8. Spring Boot笔记--Spring Boot相关介绍+快速入门

    相关介绍 简化了Spring开发,避免了Spring开发的繁琐过程 提供了自动配置.起步依赖.辅助功能 快速入门 结果呈现: 相关过程: helloController.java package or ...

  9. Activiti7开发(三)-流程实例

    目录 0.前言 1.创建流程实例 2.撤销申请(未实现) 3.查看审批历史(流程实例) 4.查看审批高亮图 0.前言 流程实例是与业务相关联的,先介绍一下业务:用户申请物品,领导进行审批(同意/拒绝) ...

  10. maui BlazorWebView+本地html (vue、uniapp等都可以) 接入微信sdk 开发 Android app

    首先添加微信sdk的绑定库 nuget 包:Chi.MauiBinding.Android.WeChat 项目地址:https://github.com/realZhangChi/MauiBindin ...