花下猫语:在 Python 中是否可以实现中文数字的四则运算呢?答案是肯定的。今天分享的文章,会对这个问题给出令人满意的解答。这个操作可能不会被大家用于实际的项目中,它的意义并不在此。之所以分享这篇文章,一方面是我觉得这个问题有点意思,另一方面则是因为它的实现过程很好地讲解了几个魔术方法的用途。

pythonif可以做变量吗 python中可以用for作为变量名吗_变量名

图 | 宫崎骏电影《侧耳倾听》

在Python 3里面,中文是可以作为变量名的,而运算符又可以重载,基于这两个特性,我们可以实现阿拉伯数字与中文数字的四则运算。

首先我们定义一个类 Num:

class Num(object):
 
   
  
 def __init__(self, n):
 
   
  
 self.n = n
 
   
  
 def __repr__(self):
 
   
  
 return self.n
 
   
  
 def __str__(self):
 
   
  
 return str(self.n)


然后把这个类初始化为各个中文数字:

一 = Num(1)
 
   
  
五 = Num(5)
 
   
  
八 = Num(8)

运行效果如下图所示:

pythonif可以做变量吗 python中可以用for作为变量名吗_pythonif可以做变量吗_02

代码里面,通过实现 __repr__,能实现在 Jupyter 或者Python命令行交互环境里面输入变量名回车就显示变量的值。

通过实现 __str__,能实现在Python 里面 print(变量)的时候打印出具体的值。

但现在还不够,当我们进行四则运算的时候,会报错:

pythonif可以做变量吗 python中可以用for作为变量名吗_变量名_03

为了能够正常实现 一+1,我们需要实现 __add__方法:

class Num(object):
 
   
  
 def __init__(self, n):
 
   
  
 self.n = n
 
   
  
 def __repr__(self):
 
   
  
 return str(self.n)
 
   
  
 def __str__(self):
 
   
  
 return str(self.n)
 
   
  
 def __add__(self, x):
 
   
  
 return self.n + x

运行效果如下图所示:

pythonif可以做变量吗 python中可以用for作为变量名吗_四则运算_04

但是,如果我们把加号两侧的数字兑换一下,代码又报错了,如下图所示:

pythonif可以做变量吗 python中可以用for作为变量名吗_可以使用中文作为变量名_05

这是由于,当我们执行 a+b的时候,Python会调用 a对象里面的 __add__方法,所以当我们执行 一+1的时候,调用的是 一里面的 __add__方法,这是我们自己写的,所以能够正常运行。

但是当我们执行 1+一的时候,调用的是 1里面的 __add__方法。在Python里面,数字对象里面的 __add__方法只能实现数字加数字。

但是我们不能修改Python 内置数字的 __add__方法,所以我们需要使用 __radd__方法。它的作用是,在 1+一执行的时候,如果 1里面的 __add__运行失败了,那么就会调用 一里面的 __radd__:

class Num(object):
 
   
  
 def __init__(self, n):
 
   
  
 self.n = n
 
   
  
 def __repr__(self):
 
   
  
 return str(self.n)
 
   
  
 def __str__(self):
 
   
  
 return str(self.n)
 
   
  
 def __add__(self, x):
 
   
  
 return self.n + x
 
   
  
 def __radd__(self, x):
 
   
  
 return self.n + x


运行效果如下图所示:

pythonif可以做变量吗 python中可以用for作为变量名吗_pythonif可以做变量吗_06

同样的原理,你可以自己实现减法 __sub__/__rsub__、乘法 __mul__/__rmul__和除法 __truediv__/__rtruediv__。