Python算术运算符 图片看不了?点击切换HTTP 返回上层
算术运算符是处理四则运算的符号,在数字的处理中应用得最多。Python 支持所有的基本算术运算符,如表 1 所示。
例如,在 Python 2.x 的交互式解释执行器中执行如下代码:
由于求余运算也需要进行除法运算,因此求余运算的第二个操作数不能是 0,否则程序会报出 ZeroDivisionError 错误。
例如如下程序:
运算符 | 说明 | 实例 | 结果 |
---|---|---|---|
+ | 加 | 12.45 + 15 | 27.45 |
- | 减 | 4.56 - 0.26 | 4.3 |
* | 乘 | 5 * 3.6 | 18.0 |
/ | 除 | 7 / 2 | 3.5 |
% | 取余,即返回除法的余数 | 7 % 2 | 1 |
// | 整除,返回商的整数部分 | 7 // 2 | 3 |
** | 幂,即返回 x 的 y 次方 | 2 ** 4 | 16,即 24 |
接下来将对表 1 中各个算术运算符的用法,一一做详细讲解。
+ 加法运算符
例如如下代码:a = 5.2 b = 3.1 the_sum = a + b # sum的值为8.3 print("the_sum的值为:", the_sum)除此之外,“+”还可以作为字符串(包括后续要介绍的序列)的连接运算符。例如如下代码:
s1 = 'Hello, ' s2 = 'Charlie' # 使用+连接两个字符串 print(s1 + s2)
- 减法运算符
例如如下代码:c = 5.2 d = 3.1 sub = c - d # sub的值为2.1 print("sub的值为:", sub)此外,“-”除了可以作为减法运算符之外,还可以作为求负的运算符。请看如下代码:
# 定义变量x,其值为-5.0 x = -5.0 # 将x求负,其值变成5.0 x = -x print(x)但单目运算符“+”则不对操作数做任何改变,例如如下代码:
# 定义变量y,其值为-5.0 y = -5.0 # y值依然是-5.0 y = +y print(y)
*乘法运算符
例如如下代码:e = 5.2 f = 3.1 multiply = e * f # multiply的值为16.12 print("multiply的值为:", multiply)此外,“*”还可以作为字符串(包括后续要介绍的序列)的连接运算符,表示将 N 个字符串连接起来。例如如下代码:
s3 = 'crazyit ' # 使用*将5个字符串连接起来 print(s3 * 5)上面代码将会输出:
crazyit crazyit crazyit crazyit crazyit
/ 和 // 除法运算符
Python 的除法运算符有两个:“/”表示普通除法,使用它除出来的结果与平常数学计算的结果是相同的(即除不尽时,会产生小数部分);而“//”表示整除,使用它除出来的结果只有整数部分,小数部分将会被舍弃。例如如下代码:print("19/4的结果是:", 19/4) print("19//4的结果是:", 19//4) aa = 5.2 bb = 3.1 # aa / bb的值将是1.67741935483871 print("aa/bb的值是:", aa / bb) # aa // bb值将是1.0 print("aa//bb的值是:", aa // bb)此外,Python 不允许使用 0 作为除数,否则将会引发 ZeroDivisionError 错误。
在有些编程语言中,0 作为除数会得到无穷大,包括正无穷大或负无穷大。
对于 Python 2.x 而言,它只提供了一个“/”运算符,该运算符是 Python 3.x 中“/”和“//”的综合版。对于 Python 2.x 中的“/”而言,它既是整除运算符,也是非整除运算符。规则如下:- 当两个操作数都是整数时,Python 2.x 中的“/”就是整除运算符。
- 当两个操作数有一个是浮点数(或两个都是浮点数)时,Python 2.x 中的“/”就是非整除运算符。
例如,在 Python 2.x 的交互式解释执行器中执行如下代码:
>>>print(5/2)
2
>>>print(5.0/2)
2.5
>>>print(5/2.0)
2.5
>>>print(5.0/2.0)
2.5
% 求余运算符
Python 不要求求余运算符的两个操作数都是整数,Python 的求余运算符完全支持对浮点数求余。求余运算的结果不一定总是整数,它是使用第一个操作数来除以第二个操作数,得到一个整除的结果后剩下的值就是余数。由于求余运算也需要进行除法运算,因此求余运算的第二个操作数不能是 0,否则程序会报出 ZeroDivisionError 错误。
例如如下程序:
print("5%3的值为:", 5 % 3) # 输出2 print("5.2%3.1的值为:",5.2 % 3.1) # 输出2.1 print("-5.2%-3.1的值为:", -5.2 % -3.1) # 输出-2.1 print("5.2%-2.9的值为:", 5.2 % -2.9) # 输出-0.6 print("5.2%-1.5的值为:", 5.2 % -1.5) # 输出-0.8 print("-5.2%1.5的值为:", -5.2 % 1.5) # 输出0.8 #print("5对0.0求余的结果是:", 5 % 0.0) # 导致错误这里需要注意的一点是,使用 % 求余,如果除数(第二个操作数)是负数,那么取得的结果也一定是负数。因此,运行上面程序,可以看到如下输出结果:
5%3的值为: 2
5.2%3.1的值为: 2.1
-5.2%-3.1的值为: -2.1
5.2%-2.9的值为: -0.5999999999999996
5.2%-1.5的值为: -0.7999999999999998
-5.2%1.5的值为: 0.7999999999999998
- 第一个问题,为什么预计 5.2 % 2.9 的结果是 -0.6 呢?因为 Python 求余运算的逻辑是用被除数减去除数的 N 倍,此处的 N 是 -2,因此得到结果是 0.6。
- 第二个问题,为什么实际输出的是 -0.5999999999999996 呢?这是由浮点数的存储机制导致的。计算机底层的浮点数的存储机制并不是精确保存每一个浮点数的值,读者暂时不需要花太多的时间去理解浮点数的存储机制,只要知道浮点数在 Python 中可能产生精度丢失的问题就行。比如此处正常计算的结果应该是 -0.6,但实际计算出来的结果是一个非常接近 -0.6 的值。
** 乘方运算符
Python 支持使用“**”作为乘方运算符,这是一个使用非常方便的运算符。由于开方其实是乘方的逆运算,因此实际上使用“**”也可进行开方运算。例如如下代码:print('5 的 2 次方:', 5 ** 2) # 25 print('4 的 3 次方:', 4 ** 3) # 64 print('4 的开平方:', 4 ** 0.5) # 2.0 print('27 的开 3 次方:',27 **(1 / 3 )) # 3.0