百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python之鸭子类型:魔术方法&自定义类型也可以实现加减乘除

off999 2024-12-14 14:26 15 浏览 0 评论

引言

上一篇文章中,我们简单聊了通过定义魔术方法,自定义类型也可以像内置的整型、浮点型等一样,也能进行比较运算。今天,我们接着聊运算符重载的话题,通过魔术方法实现自定义类型四则运算的功能。

需要说明的是,虽然,我们一直在用“运算符重载”这个名词,实际上是C++等编程语言中的技术,Java中虽然支持函数重载,但是也不支持运算符重载,所以很难实现类似于内置类型的操作。Python虽然没有运算符重载的功能,但是,魔术方法实现了运算符重载同样的功能。

本文的主要内容有:

1、算术运算符的分类

2、算术运算相关的魔术方法

3、自定义类型实现算术运算操作


算术运算符的分类

算术运算符常见的分类方法有如下几种:

1、按照参与运算的对象个数,可以分为一元运算符和二元运算符。

2、按照真正调用方法的对象来看,二元运算符中,又可以分为正向运算(左侧对象真正调用方法)和反向运算(右侧对象真正调用方法)。

3、按照运算符的结果来看,又可以分为普通运算符(不可变操作对象本身)和增量运算符(改变操作对象本身)。

这不同的算术运算符,在Python中都有对应的魔术方法,我们在实际业务中,可以根据操作的需要,自由选择实现其中某个或者某几个的组合。


算术运算相关的魔术方法

下面简单列举一下Python中关于算术运算相关的魔术方法。

首先是正向的运算符所对应的魔术方法:

1、__add__(self, other):正向加法运算。

2、__sub__(self, other):正向减法运算。

3、__mul__(self, other):正向乘法运算。

4、__truediv__(self, other):正向除法运算。

5、__floordiv__(self, other):正向地板除法运算。

6、__mod__(self, other):正向取模运算。

7、__pow__(self, other):正向幂运算。


其次是反向运算符所对应的魔术方法:

1、__radd__(self, other):反向加法运算。

2、__rsub__(self, other):反向减法运算。

3、__rmul__(self, other):反向乘法运算。

4、__rtruediv__(self, other):反向除法运算。

5、__rfloordiv__(self, other):反向地板除法运算。

6、__rmod__(self, other):反向取模运算。

7、__rpow__(self, other):反向幂运算。


可以看到,每个反向运算符对应的魔术方法,都是正向方法前面多了一个前缀r,表示“reverse”。


然后是增量运算符(原地运算)所对应的魔术方法:

1、__iadd__(self, other):增量加法运算。

2、__isub__(self, other):增量减法运算。

3、__imul__(self, other):增量乘法运算。

4、__itruediv__(self, other):增量除法运算。

5、__ifloordiv__(self, other):增量地板除法运算。

6、__imod__(self, other):增量取模运算。

7、__ipow__(self, other):增量幂运算。


可以看到,每个增量运算符的魔术方法,前面的前缀都是i,表示inplace的意思。


最后再来看一下,一元操作符所对应的魔术方法:

1、__neg__(self):只有一个参数,用于实现-self。

2、__pos__(self):只有一个参数,用于实现+self。

3、__invert__(self):只有一个参数,用于实现~self。


自定义类型实现算术运算操作

接下来,简单通过代码演示一下几个常见的算术运算相关的魔术方法的使用。

直接看代码:

class Vector:
    def __init__(self, x, y):
        self.x = x
        self.y = y

    # 正向加
    def __add__(self, other):
        if isinstance(other, self.__class__):
            return self.__class__(self.x + other.x, self.y + other.y)
        if isinstance(other, tuple) and len(other) == 2:
            return self.__class__(self.x + other[0], self.y + other[1])
        raise NotImplemented

    # 反向减
    def __rsub__(self, other):
        if isinstance(other, self.__class__):
            return self.__class__(other.x - self.x, other.y - self.y)
        if isinstance(other, tuple) and len(other) == 2:
            return self.__class__(other[0] - self.x, other[1] - self.y)
        raise NotImplemented

    # 原地加
    def __iadd__(self, other):
        if isinstance(other, self.__class__):
            self.x += other.x
            self.y += other.y
            return self
        raise NotImplemented

    # 一元运算
    def __neg__(self):
        return self.__class__(-self.x, -self.y)

    def __str__(self):
        return f'Vector({self.x}, {self.y})'


if __name__ == '__main__':
    v1 = Vector(10, 20)
    print(v1)
    v2 = Vector(100, 200)
    print(v2)
    v3 = v1 + v2
    print(v3)
    v4 = v1 + (1, 2)
    print(v4)
    v5 = -v2
    print(v5)
    v5 += v1
    print(v5)

运行结果:


总结

本文简单介绍了算术运算符的分类,比如:一元运算符、二元运算符、增量运算符、反向运算符等。然后,又列举了常见的算术运算符对应的魔术方法。最后通过一个向量类的实例,演示了算术运算符相关魔术方法的使用。

感谢您的拨冗阅读,希望对您有所帮助!

相关推荐

独家 | 5 个Python高级特性让你在不知不觉中成为Python高手

你已经使用Python编程了一段时间,编写脚本并解决各种问题。是你的水平出色吗?你可能只是在不知不觉中利用了Python的高级特性。从闭包(closure)到上下文管理器(contextmana...

Python装饰器

Python装饰器是一种用于修改函数或类的行为的特殊语法。它们允许在不修改原始代码的情况下,通过将函数或类作为参数传递给另一个函数来添加额外的功能。装饰器本质上是一个函数,它接受一个函数作为参数,并返...

中高阶Python常规用法--上下文管理器

Python以简单性和通用性著称,是一种深受全球开发人员喜爱的编程语言。它提供了大量的特性和功能,使编码成为一种愉快的体验。在这些功能中,一个经常被新手忽视的强大工具是上下文管理器。上下文管理器是高...

Python小案例67- 装饰器

Python装饰器是一种用于修改函数或类的行为的特殊语法。它们允许在不修改原始代码的情况下,通过将函数或类作为参数传递给另一个函数来添加额外的功能。装饰器本质上是一个函数,它接受一个函数作为参数,并返...

python常用的语法糖

概念Python的语法糖(SyntacticSugar)是指那些让代码更简洁、更易读的语法特性,它们本质上并不会增加新功能,但能让开发者更高效地编写代码。推导式写法推导式是Python最经典的...

python - 常用的装饰器 decorator 有哪些?

python编程中使用装饰器(decorator)工具,可以使代码更简洁清晰,提高代码的重用性,还可以为代码维护提供方便。对于python初学者来说,根据装饰器(decorator)的字面意思并不...

python数据缓存怎么搞 ?推荐一个三方包供你参考,非常简单好用。

1.数据缓存说明数据缓存可以说也是项目开发中比不可少的一个工具,像我们测试的系统中,你都会见到像Redis一样的数据缓存库。使用缓存数据库的好处不言而喻,那就是效率高,简单数据直接放在缓存中...

用于时间序列数据的Graphite监视工具

结合第三方工具,Graphite为IT性能监控提供了许多好处。本文介绍其核心组件,包括Carbon、Whisper以及安装的基本准则。Graphite监视工具可实时或按需,大规模地绘制来自多个来源的时...

Python3+pygame实现的坦克大战

一、显示效果二、代码1.说明几乎所有pygame游戏,基本都遵循一定的开发流程,大体如下:初始化pygame创建窗口while循环检测以及处理事件(鼠标点击、按键等)更新UI界面2.代码创建一个m...

Python之鸭子类型:一次搞懂with与上下文装饰器

引言在鸭子类型的理念的基础之上,从关注类型,转变到关注特性和行为。结合Python中的魔法函数的体系,我们可以将自定义的类型,像内置类型一样被使用。今天这篇文章中,接着该话题,继续聊一下with语法块...

Python必会的50个代码操作

学习Python时,掌握一些常用的程序操作非常重要。以下是50个Python必会的程序操作,主要包括基础语法、数据结构、函数和文件操作等。1.HelloWorldprint("Hello,...

一文掌握Python 中的同步和异步

同步代码(Sync)同步就像在一个流水线上工作,每个任务都等待前一个任务完成。示例:机器A切割钢板→完成后,机器B钻孔→完成后,机器C上色。在Python中,同步代码看起来像这样:im...

python 标注模块timeit: 测试函数的运行时间

在Python中,可以使用内置的timeit模块来测试函数的运行时间。timeit模块提供了一个简单的接口来测量小段代码的执行时间。以下是使用timeit测试函数运行时间的一般步骤:导入...

Python带你找回童年的万花尺

还记得小时候的万花尺吧?这么画:一点也不费脑筋,就可以出来这么多丰富多彩的复杂几何图形。具体而言,可以用万花尺玩具(如图2-1所示)来绘制数学曲线。这种玩具由两个不同尺寸的塑料齿轮组成,一大一小。小的...

Python 时间模块深度解析:从基础到高级的全面指南

直接上干货一、时间模块核心类介绍序号类名说明1datetime.datetime表示一个具体的日期和时间,结合了日期和时间的信息。2datetime.date表示一个具体的日期。3datetime.t...

取消回复欢迎 发表评论: