Python3.0 语言支持的运算符有:python
算术运算符、比较(关系)运算符、赋值运算符、逻辑运算符、位运算符、成员运算符、身份运算符、运算符优先级函数
常见的算术运算符有+,-,*,/,%,这些比较常见,就忽略不说了,主要说明下Python3.0中的另外两个算术运算符:测试
* 幂 - 返回x的y次幂,好比2**3,即2的3次方。spa
// 取整除 - 向下取接近除数的整数,注意正数和负数的区别所在。code
>>> 9//2 4 >>> -9//2 -5
常见的比较运算符有:==、!=、>、<、>=、<=。这儿也不作详细说明。对象
常见的赋值运算符:=简单的赋值运算符、+=加法赋值运算符、-=减法赋值运算符、*=乘法赋值运算符、/=除法赋值运算符、%=取模赋值运算符、**=幂赋值运算符、//=取整除赋值运算符blog
这儿注意的是,在Python语言中,没有++或者--的操做这个与其余语言要注意区别。或者会报错,如图所示:内存
不使用 ++ 的哲学逻辑:编译解析上的简洁与语言自己的简洁,ci
正确的自增操做应该 a = a + 1 或者 a += 1,当此 a 自增后,经过 id() 观察可知,id 值变化了,即 a 已是新值的名称。字符串
Python语言支持逻辑运算符,如下假设变量 a 为 10, b为 20:
运算符 |
逻辑表达式 |
描述 |
实例 |
and |
x and y |
布尔"与" - 若是 x 为 False,x and y 返回 False,不然它返回 y 的计算值。 |
(a and b) 返回 20。 |
or |
x or y |
布尔"或" - 若是 x 是 True,它返回 x 的值,不然它返回 y 的计算值。 |
(a or b) 返回 10。 |
not |
not x |
布尔"非" - 若是 x 为 True,返回 False 。若是 x 为 False,它返回 True。 |
not(a and b) 返回 False |
来看下and or not的运算例子。优先级:not>and>or
and:前面为假(0 或者 False)则表达式为假,不然表达式为后面的值; or:前面为真(非 0 或者非 False)则表达式为前面的值,不然表达式为后面的值;
python位运算是把数字看着二进制来运算的。如下例子运算中a=60,b=13:
运算符 |
描述 |
实例 |
---|---|---|
& | 按位与运算符:参与运算的两个值,若是两个相应位都为1,则该位的结果为1,不然为0 | (a & b) 输出结果 12 ,二进制解释: 0000 1100 |
| | 按位或运算符:只要对应的二个二进位有一个为1时,结果位就为1。 | (a | b) 输出结果 61 ,二进制解释: 0011 1101 |
^ | 按位异或运算符:当两对应的二进位相异时,结果为1 | (a ^ b) 输出结果 49 ,二进制解释: 0011 0001 |
~ | 按位取反运算符:对数据的每一个二进制位取反,即把1变为0,把0变为1 。~x相似于 -x-1 | (~a ) 输出结果 -61 ,二进制解释: 1100 0011,在一个有符号二进制数的补码形式。 |
<< | 左移动运算符:运算数的各二进位所有左移若干位,由 << 右边的数字指定了移动的位数,高位丢弃,低位补0。 | a << 2 输出结果 240 ,二进制解释: 1111 0000 |
>> | 右移动运算符:把">>"左边的运算数的各二进位所有右移若干位,>> 右边的数字指定了移动的位数 | a >> 2 输出结果 15 ,二进制解释: 0000 1111 |
除了以上的一些运算符以外,Python还支持成员运算符,测试实例中包含了一系列的成员,包括字符串,列表或元组。
运算符 |
描述 |
实例 |
in |
若是在指定的序列中找到值返回 True,不然返回 False。 |
x 在 y 序列中 , 若是 x 在 y 序列中返回 True。 |
not in |
若是在指定的序列中没有找到值返回 True,不然返回 False。 |
x 不在 y 序列中 , 若是 x 不在 y 序列中返回 True。 |
身份运算符用于比较两个对象的存储单元
运算符 |
描述 |
实例 |
---|---|---|
is | is 是判断两个标识符是否是引用自一个对象 | x is y, 相似 id(x) == id(y) , 若是引用的是同一个对象则返回 True,不然返回 False |
is not | is not 是判断两个标识符是否是引用自不一样对象 | x is not y , 相似 id(a) != id(b)。若是引用的不是同一个对象则返回结果 True,不然返回 False。 |
注: id() 函数用于获取对象内存地址。
is 与 == 区别: is 用于判断两个变量引用对象是否为同一个(同一块内存空间)即内存地址, 判断两个对象是否为同一对象, 是经过 id 来判断的; 当两个基本类型数据(或元组)内容相同时, id 会相同, 但并不表明 a 会随 b 的改变而改变。 == 用于判断引用变量的值是否相等。 判断两个对象的内容是否相同, 是经过调用 __eq__() 来判断的。
例子1:
a = 20 b = 20 if ( id(a) == id(b) ): print ("2 - a 和 b 有相同的标识") else: print ("2 - a 和 b 没有相同的标识")
例子2:
a = [1, 2, 3] b = a print("b is a :", b is a) print("b == a :", b == a) b = a[:] print("b is a :", b is a) ##虽然值同样,可是内存地址不同。 print("b == a :", b == a)
结果:
例子3
# 当列表,元组,字典中的值都引用 a,b 时,老是返回 True,不受 a,b 值大小的影响 a=1000 b=1000 list1=[a,3,5] list2=[b,4,5] print(list1[0] is list2[0]) # >>>>> True tuple1=(a,3,5) tuple2=(b,4,5) print(tuple1[0] is tuple2[0]) # >>>>> True dict1={6:a,2:3,3:5} dict2={1:b,2:4,3:7} print(dict1[6] is dict2[1]) # >>>>> True print("-------------------------------------------------------") # 当不引用a,b,直接用具体值来测试时,列表,字典,不受值大小影响,返回True,元组则受 256 值范围的影响,超出范围则地址改变,返回 False。 list1=[1000,3,5] list2=[1000,4,5] print(list1[0] is list2[0]) # >>>>> True tuple1=(1000,3,5) tuple2=(1000,4,5) print(tuple1[0] is tuple2[0]) # >>>>> False dict1={6:1000,2:3,3:5} dict2={1:1000,2:4,3:7} print(dict1[6] is dict2[1]) # >>>>> True print("-------------------------------------------------------") # 当直接用列表、元组、字典自己来测试时,恰好相反,元组返回 True,列表,字典返回 False。 list1=[1000,3,5] list2=[1000,3,5] print(list1 is list2) # >>>>> False tuple1=(1000,3,5) tuple2=(1000,3,5) print(tuple1 is tuple2) # >>>>> True dict1={1:1000,2:3,3:5} dict2={1:1000,2:3,3:5} print(dict1 is dict2) # >>>>> False
如下表格列出了从最高到最低优先级的全部运算符:
运算符 | 描述 |
---|---|
** | 指数 (最高优先级) |
~ + - | 按位翻转, 一元加号和减号 (最后两个的方法名为 +@ 和 -@) |
* / % // | 乘,除,取模和取整除 |
+ - | 加法减法 |
>> << | 右移,左移运算符 |
& | 位 'AND' |
^ | | 位运算符 |
<= < > >= | 比较运算符 |
<> == != | 等于运算符 |
= %= /= //= -= += *= **= | 赋值运算符 |
is is not | 身份运算符 |
in not in | 成员运算符 |
not and or | 逻辑运算符 |