下面以a=10 ,b=20为例进行计算。
运算符 | 描述 | 实例 |
---|---|---|
+ | 加 | 两个对象相加 a + b 输出结果 30 |
- | 减 | 得到负数或是一个数减去另一个数 a - b 输出结果 -10 |
* | 乘 | 两个数相乘或是返回一个被重复若干次的字符串 a * b 输出结果 200 |
/ | 除 | b / a 输出结果,如果是Python2输出2,如果是python3输出2.0 |
// | 取整除 | 返回商的整数部分 9//2 输出结果 4 , 9.0//2.0 输出结果 4.0,向下取整,-5//2结果是-3 |
% | 取余 | 返回除法的余数 b % a 输出结果 0 |
** | 指数 | a**b 为10的20次方, 输出结果 100000000000000000000 |
() | 小括号 | 提高运算优先级,比如: (1+2) * 3 |
注意:混合运算时,优先级顺序为:?**
?高于?* / % //
?高于?+ -
?,为了避免歧义,建议使用 () 来处理运算符优先级。 并且,不同类型的数字在进行混合运算时,整数将会转换成浮点数进行运算。
字符串里有限度的支持加法和乘法运算符
加法运算符:只能用于两个字串类型的数据,用来拼接两个字符串,字符串和数字之间用加法运算符会报错。
C:\Users>python3
Python 3.6.5 (v3.6.5:f59c0932b4, Mar 28 2018, 17:00:18) [MSC v.1900 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> a = 'Hello'
>>> b = 'Word'
>>> print(a+b)
HelloWord
>>> a = 'Hello'
>>> c = 123
>>> print(a+c)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: must be str, not int
如果是数字和字符串做乘法运算,会将这个字符串重复多次。
C:\Users>python3
Python 3.6.5 (v3.6.5:f59c0932b4, Mar 28 2018, 17:00:18) [MSC v.1900 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> 'hello'*3
'hellohellohello'
运算符 | 描述 | 实例 |
---|---|---|
= | 赋值运算符 | 把 = 号右边的结果 赋给 左边的变量,如 num = 1 + 2 * 3,结果num的值为7 |
注意:赋值运算符是从右往左运算,将等号右边的值赋值给等号左边,所以,等号的左边一定不能是常量或者表达式。
运算符 | 描述 | 实例 |
---|---|---|
+= | 加法赋值运算符 | c += a 等效于 c = c + a |
-= | 减法赋值运算符 | c -= a 等效于 c = c - a |
*= | 乘法赋值运算符 | c *= a 等效于 c = c * a |
/= | 除法赋值运算符 | c /= a 等效于 c = c / a |
//= | 取整除赋值运算符 | c //= a 等效于 c = c // a |
%= | 取模赋值运算符 | c %= a 等效于 c = c % a |
**= | 幂赋值运算符 | c **= a 等效于 c = c ** a |
C:\Users>python3
Python 3.6.5 (v3.6.5:f59c0932b4, Mar 28 2018, 17:00:18) [MSC v.1900 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> a = b = c = d = 'Hello'
>>> print(a,b,c,d)
Hello Hello Hello Hello
>>>
相当于省略了元组的小括号,要注意拆包时变量的个数和值的个数要一一对应。
C:\Users>python3
Python 3.6.5 (v3.6.5:f59c0932b4, Mar 28 2018, 17:00:18) [MSC v.1900 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> m,n = 3,5
>>> print(m,n)
3 5
>>> x = 'hello','good','yes'
>>> print(x)
('hello', 'good', 'yes')
>>> type(x)
<class 'tuple'>
C:\Users>python3
Python 3.6.5 (v3.6.5:f59c0932b4, Mar 28 2018, 17:00:18) [MSC v.1900 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> o,*p,q=1,2,3,4,5,6,7
>>> print(o,p,q)
1 [2, 3, 4, 5, 6] 7
>>> type(o)
<class 'int'>
>>> type(q)
<class 'int'>
>>> type(p)
<class 'list'>
以下假设变量a为10,变量b为20:
运算符 | 描述 | 实例 |
---|---|---|
== | 等于 - 比较对象是否相等 | (a == b) 返回 False. |
!= | 不等于 - 比较两个对象是否不相等 | (a != b) 返回 true. |
<> | 不等于 - 比较两个对象是否不相等 | (a <> b) 返回 true。这个运算符类似 != 。 |
> | 大于 - 返回x是否大于y | (a > b) 返回 False。 |
< | 小于 - 返回x是否小于y。所有比较运算符返回1表示真,返回0表示假。这分别与特殊的变量True和False等价。 | (a < b) 返回 true。 |
>= | 大于等于 - 返回x是否大于等于y。 | (a >= b) 返回 False。 |
<= | 小于等于 - 返回x是否小于等于y。 | (a <= b) 返回 true。 |
如果是两个字符串进行比较,会将每个字符都转换成对应的编码,然后逐一进行对比。
# 比较运算符在字符串里的使用
# 字符串之间使用比较运算符,会根据各个字符的编码值逐一进行比较
# ASCII码表
print('a' > 'b') # False 97>98
print('abc' > 'b') # False 97>98 逐一比较,比较出结果就不比较下面了
# 数字和字符串之间,做 == 运算的结是FaLse,做 != 结是True,不支其他的比较运算
print('a' == 90) # False
print('a' != 97) # True
运算符 | 逻辑表达式 | 描述 | 实 |
---|---|---|---|
and | x and y | 只要有一个运算数是False,结果就是False; 只有所有的运算数都为True时,结果才是True 做取值运算时,取第一个为False的值,如果所有的值都为True,取最后一个值。 | True and True and False-->结果为False True and True and True-->结果为True 1 and 0 and 2-->结果是0;1 and 2 and 3-->结果是3 |
or | x or y | 只要有一个运算数是True,结果就是True; 只有所有的运算数都为False时,结果才是False 做取值运算时,取第一个为True的值,如果所有的值都为False,取最后一个值。 | False or False or True-->结果为True False or False or False-->结果为False 1 or 0 or 2-->结果是1;0 or None or () or '' or {} -->结果是{} |
not | not x | 布尔"非" - 如果 x 为 True,返回 False 。如果 x 为 False,它返回 True。 | not(a and b) 返回 False |
a = 34
b = 12
print((a > b) and (b > 10) and (a > 30) and (a > 50)) # False
print((a > b) and (b > 10) and (a > 30) and (a < 50)) # True
print(a and b and 'hello' and 0 and 123) # 0
print(a and b and 'hello' and 123 and 'hi') # hi
print((a > 50) or (b < 10) or a > b or (a == b)) # True
print((a > 50) or (b < 10) or a < b or (a == b)) # False
print(0 or None or a or '') # 34
print(0 or "" or '' or None) # None
a = 34
a > 10 and print('a > 10----' + 'hello world') # a > 10----hello world
a < 10 and print('a < 10----' + 'hello world') # 无输出
a > 10 or print('a > 10----' + '你好世界') # 无输出
a < 10 or print('a < 10----' + '你好世界') # a < 10----你好世界
逻辑运算的结果不一定是布尔值
位运算 | 描述 | 示例 |
---|---|---|
& | 按位与运算符:参与运算的两个值,如果两个相应位都为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 |
按位运算符是把数字看作是二进制来进行计算的。 下表中变量 a 为 60,b 为 13,二进制格式如下:
a = 0011 1100 # 60的二进制
b = 0000 1101 # 13的二进制
-----------------
a&b = 0000 1100
a|b = 0011 1101
a^b = 0011 0001
~a = 1100 0011
X=5
print(x << 3)
#a<<n ==>a*2的n次方
y = 15
print(y >> 2)
#a >>n ==>a 除以 2的n次方
当多种运算符做混合运算时,就会涉及到先运算哪个,后运算哪个问题。以下表格列出了从最高到最低优先级的所有运算符:
运算符 | 描述 |
---|---|
** | 指数 (最高优先级) |
~ + - | 按位翻转, 一元加号和减号 (最后两个的方法名为 +@ 和 -@) |
* / % // | 乘,除,取模和取整除 |
+ - | 加法减法 |
>> << | 右移,左移运算符 |
& | 位 'AND' |
^ | | 位运算符 |
<= < > >= | 比较运算符 |
<> == != | 等于运算符 |
= %= /= //= -= += *= **= | 赋值运算符 |
is is not | 身份运算符 |
in not in | 成员运算符 |
not>and>or | 逻辑运算符 |