python之有关魔方方法的内容

简介: python之有关魔方方法的内容

魔方方法:

在python的类中,以下划线开头,两个下划线结尾的方法,如常见的:init,str,__del__等,就被称为魔方方法,这些方法在类或对象进行特定的操作时会被自动调用,我们可以使用或重写这些魔方方法,给自定义的类添加各种特殊的功能来满足自己的需求。


常见的魔方方法:

init:

init()方法是我们最常见的魔方方法,可以用此方法定义一个对象的初始化操作。

例如:

class Car:
def __init__(self,Color,WheelNum):
        self.color = Color#初始化操作,不设定值
        self.wheelNum = WheelNum

new:

init()方法很容易被认为是在实例化对象时,调用的第一个方法,但其实不是,当我们实例化一个对象的时候,第一个被调用的方法是__new__(),而后再调用__init__()方法,并把一些参数传给__init__()方法,new()方法才是真正创建了实例化对象,init()方法只是给这个对象进行了初始化操作。


举例:

class Car:
    def __init__(self,color,wheelnum):
        print("__init__()方法被调用")
        self.color=color
        self.wheelnum=wheelnum
         print(id((self)))
    def __new__(cls, *args, **kwargs):#接收任意数量的位置实参和关键字实参
        print("__new__()方法被调用")
        print("args:",args)
        c=super().__new__(cls)#cls表示当前类
        print(id(c))
        return c#有返回,调用__init__函数
my_car=Car("蓝色",8)
__new__()方法被调用#new函数先被调用
args: ('蓝色', 8)
1955709945024
__init__()方法被调用
1955709945024

new()方法第一个参数必须是cls参数,表示当前类,其他参数是用来直接传递给__init__方法,__new__决定是否要使用该__init__方法,因为__new__可以调用其他类的构造方法或直接返回别的实例对象来作为本类的实例,如果__new__没有返回实例对象,则__init__不会被调用,__new__主要是用于继承一个不可变的类型,例如:元组或者字符串


del:

当一个对象的生命周期结束被彻底销毁的时候被调用,编译器会默认调用__del__方法.

class Car:
    def __init__(self,color,wheelnum):
        print("__init__()方法被调用")
        self.color=color
        self.wheelnum=wheelnum
    def __del__(self):
        print("__del__()方法被调用")#被调用后,该变量所占用的内存块被释放
my_car=Car("蓝色",8)
print(my_car.color)

__new__和__init__的id值相同,它两相配合才是python中真正的类构造器

__init__()方法被调用
蓝色
__del__()方法被调用

str:

如果要把一个类的实例变成str,就需要实现特殊方法__str__()

举例:

class Car:
    def __init__(self,color,wheelnum):
        print("__init__()方法被调用")
        self.color=color
        self.wheelnum=wheelnum
    def __str__(self):#将实例转化为字符串
        return (f"我的汽车颜色是{self.color},它有{self.wheelnum}个轮子")
my_car=Car("蓝色",8)
print(my_car)
__init__()方法被调用
我的汽车颜色是蓝色,它有8个轮子

setattr函数和getattr函数

setattr()函数用于设置属性,该属性不一定存在。

def __setattr__(object,key,value):#object---对象,key----字符串,对象属性,value----属

举例:

class Car:
    def __init__(self,color,wheelnum):
        print("__init__()方法被调用")
        self.color="红色"
        self.wheelnum=8
my_car=Car("蓝色",8)
print("设置属性前:")
print(my_car.color)
print(my_car.wheelnum)
setattr(my_car,"color","白色")#设置对象属性的值
setattr(my_car,"wheelnum",10)#设置对象属性的值
print("设置属性后:")
print(my_car.color)
print(my_car.wheelnum)
__init__()方法被调用
设置属性前:
红色
8
设置属性后:
白色
10

gatattr()函数用于获取属性。

def __getattr__(object,key)#object-----对象,key-----对象属性

举例:

class Car:
    def __init__(self,color,wheelnum):
        print("__init__()方法被调用")
        self.color="红色"
        self.wheelnum=8
my_car=Car("蓝色",8)
print(getattr(my_car,"color"))#输出对象对应属性的值
__init__()方法被调用
红色

类型转换相关魔方方法:

class Car:
    def __init__(self,color,wheelnum):
        print("__init__()方法被调用")
        self.color="红色"
        self.wheelnum=8
    def __int__(self):#将对应的属性wheelnum的值转化为int类型的结果并返回给__init__()函数
        return self.wheelnum
    def __float__(self):#将对应的属性wheelnum的值转化为float类型的结果并返回给__init__()函数
        return self.wheelnum*1.0
    def __str__(self):#将对应的属性color的值转化为str类型的结果并返回给__init__()函数
        return self.color
    def __bool__(self):#将对应的属性wheelnum判断的结果转化为bool类型的结果并返回给__init__()函数
        return self.wheelnum>5
my_car=Car("蓝色",8)
#强制类型转换
print(int(my_car))
print(float(my_car))
print(str(my_car))
print(bool(my_car))
__init__()方法被调用
8
8.0
红色
True

算数运算符相关的魔方方法:

class Student:
    def __init__(self,name,age):
        self.name=name
        self.age=age
    def __add__(self, other):#进行self.age+other的运算
    #并将self.age+实参的结果返回给__init__()函数
        return self.age+other
    def __sub__(self, other):
        return self.age-other
    def __mul__(self, other):
        return self.age*other
    def __truediv__(self, other):
        return self.age/other
    def __mod__(self, other):
        return self.age%other
    def __pow__(self, power, modulo=None):#平方和运算
        return self.age**power
s=Student("易烊千玺",22)
#算数运算
print(s+1)
print(s-2)
print(s*3)
print(s/4)
print(s%5)
print(s**6)
23
20
66
5.5
2
113379904

比较运算符相关的魔方方法:

class Student:
    def __init__(self,name,age):
        self.name=name
        self.age=age
    def __eq__(self, other):#比较对象的各个属性值是否都相等
        return self.name==other.name and self.age==other.age
    def __lt__(self, other):#比较对象的某一属性之间的大小关系
        return self.age<other.age
    def __le__(self, other):#比较对象的某一属性之间的大小关系
        return self.age<=other.age
student1=Student("易烊千玺",22)
student2=Student("王源",22)
student3=Student("王俊凯",23)
print(student1==student2)
print(student1!=student3)
print(student2==student3)
print(student1>=student2)
print(student1>=student3)
print(student2<=student3)
#比较运算符返回结果均为布尔值(False、True)
False
True
False
True
False
True
相关文章
|
11天前
|
JSON 数据可视化 API
Python 中调用 DeepSeek-R1 API的方法介绍,图文教程
本教程详细介绍了如何使用 Python 调用 DeepSeek 的 R1 大模型 API,适合编程新手。首先登录 DeepSeek 控制台获取 API Key,安装 Python 和 requests 库后,编写基础调用代码并运行。文末包含常见问题解答和更简单的可视化调用方法,建议收藏备用。 原文链接:[如何使用 Python 调用 DeepSeek-R1 API?](https://apifox.com/apiskills/how-to-call-the-deepseek-r1-api-using-python/)
|
26天前
|
数据挖掘 数据处理 开发者
Python3 自定义排序详解:方法与示例
Python的排序功能强大且灵活,主要通过`sorted()`函数和列表的`sort()`方法实现。两者均支持`key`参数自定义排序规则。本文详细介绍了基础排序、按字符串长度或元组元素排序、降序排序、多条件排序及使用`lambda`表达式和`functools.cmp_to_key`进行复杂排序。通过示例展示了如何对简单数据类型、字典、类对象及复杂数据结构(如列车信息)进行排序。掌握这些技巧可以显著提升数据处理能力,为编程提供更强大的支持。
32 10
|
28天前
|
人工智能 自然语言处理 算法
随机的暴力美学蒙特卡洛方法 | python小知识
蒙特卡洛方法是一种基于随机采样的计算算法,广泛应用于物理学、金融、工程等领域。它通过重复随机采样来解决复杂问题,尤其适用于难以用解析方法求解的情况。该方法起源于二战期间的曼哈顿计划,由斯坦尼斯拉夫·乌拉姆等人提出。核心思想是通过大量随机样本来近似真实结果,如估算π值的经典示例。蒙特卡洛树搜索(MCTS)是其高级应用,常用于游戏AI和决策优化。Python中可通过简单代码实现蒙特卡洛方法,展示其在文本生成等领域的潜力。随着计算能力提升,蒙特卡洛方法的应用范围不断扩大,成为处理不确定性和复杂系统的重要工具。
69 21
|
2月前
|
安全
Python-打印99乘法表的两种方法
本文详细介绍了两种实现99乘法表的方法:使用`while`循环和`for`循环。每种方法都包括了步骤解析、代码演示及优缺点分析。文章旨在帮助编程初学者理解和掌握循环结构的应用,内容通俗易懂,适合编程新手阅读。博主表示欢迎读者反馈,共同进步。
|
2月前
|
JSON 安全 API
Python调用API接口的方法
Python调用API接口的方法
410 5
|
3月前
|
机器学习/深度学习 Python
堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能
本文深入探讨了堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能。文章详细介绍了堆叠的实现步骤,包括数据准备、基础模型训练、新训练集构建及元学习器训练,并讨论了其优缺点。
165 3
|
3月前
|
机器学习/深度学习 人工智能 算法
强化学习在游戏AI中的应用,从基本原理、优势、应用场景到具体实现方法,以及Python在其中的作用
本文探讨了强化学习在游戏AI中的应用,从基本原理、优势、应用场景到具体实现方法,以及Python在其中的作用,通过案例分析展示了其潜力,并讨论了面临的挑战及未来发展趋势。强化学习正为游戏AI带来新的可能性。
216 4
|
3月前
|
算法 决策智能 Python
Python中解决TSP的方法
旅行商问题(TSP)是寻找最短路径,使旅行商能访问每个城市一次并返回起点的经典优化问题。本文介绍使用Python的`ortools`库解决TSP的方法,通过定义城市间的距离矩阵,调用库函数计算最优路径,并打印结果。此方法适用于小规模问题,对于大规模或特定需求,需深入了解算法原理及定制策略。
71 15
|
3月前
|
Python
Python编程中的魔法方法(Magic Methods)
【10月更文挑战第40天】在Python的世界中,魔法方法就像是隐藏在代码背后的神秘力量。它们通常以双下划线开头和结尾,比如 `__init__` 或 `__str__`。这些方法定义了对象的行为,当特定操作发生时自动调用。本文将揭开这些魔法方法的面纱,通过实际例子展示如何利用它们来增强你的类功能。
55 1
WK
|
3月前
|
Python
Python中format_map()方法
在Python中,`format_map()`方法用于使用字典格式化字符串。它接受一个字典作为参数,用字典中的键值对替换字符串中的占位符。此方法适用于从字典动态获取值的场景,尤其在处理大量替换值时更为清晰和方便。
WK
148 36

热门文章

最新文章

推荐镜像

更多