3.1 算术运算符
运算符 | 描述 | 实例 |
---|---|---|
+ | 加 | a+b,将两个对象相加 |
- | 减 | a-b,将两个对象相减 |
* | 乘 | a*b,将两个对象相乘 |
/ | 除 | a/b,将两个对象相除 |
// | 整除 | a//b,返回商的整数部分,9//2 = 4 , 9.0//2.0 = 4.0 |
% | 取余 | a%b,返回除法的余数,9%2 = 1 |
** | 指数 | a**b,a的b次方 |
() | 小括号 | 提高运算符的优先级 |
在混合运算时,优先级顺序为:指数高于*/%//高于+ -,为了避免歧义,建议使用()来处理运算符的优先级。并且,不同类型的数据在进行混合运算时,整数会自动转换成浮点数进行运算。
3.3.1 算数运算符在字符串里的使用
- 如果是两个字符串做加法运算,会直接把这两个字符串拼接成一个字符串。
- 如果是数字和字符串做加法运算,会直接报错。需要讲数字转换成字符串,然后做加法运算。
- 如果是数字和字符串做乘法运算,会将这个字符串重复多次。
3.2 赋值运算符
- 基本赋值运算符
=
# 单个变量赋值
>>> num = 10
>>> num
10
# 同时为多个变量赋值(使用等号连接)
>>> a = b = 4
>>> a
4
>>> b
4
>>>
# 多个变量赋值(使用逗号分隔),python独有的语法
>>> num1, f1, str1 = 100, 3.14, "hello"
>>> num1
100
>>> f1
3.14
>>> str1
"hello"
# 语法错误,值的个数超过变量的个数,赋值失败
>>> num1,num2=(1,2,3)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: too many values to unpack (expected 2)
# 语法错误,变量的个数超过值得个数,赋值失败
>>> num1,num2,num3,num4=(1,2,3)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: not enough values to unpack (expected 4, got 3)
- 复合赋值运算符
运算符 | 描述 |
---|---|
+= | 加法赋值运算符 |
-= | 减法赋值运算符 |
*= | 乘法赋值运算符 |
/= | 除法赋值运算符 |
// | 取整除赋值运算符 |
%= | 取模赋值运算符 |
**= | 幂赋值运算符 |
# 示例:+=
>>> a = 100
>>> a += 1 # 相当于执行 a = a + 1
>>> a
101
# 示例:*=
>>> a = 100
>>> a *= 2 # 相当于执行 a = a * 2
>>> a
200
# 示例:*=,运算时,符号右侧的表达式先计算出结果,再与左边变量的值运算
>>> a = 100
>>> a *= 1 + 2 # 相当于执行 a = a * (1+2)
>>> a
300
注意:赋值运算符自右向左运算,将等号右边的值赋给等号左边,所以,等号的左边一定不能是常量或者表达式。
3.3 比较运算符
比较运算符的结果是一个布尔值。
运算符 | 描述 |
---|---|
== | 等于 |
!= | 不等于 |
> | 大于 |
<> | 不等于(在python2中可以使用) |
< | 小于 |
> = | 大于等于 |
< = | 小于等于 |
3.3.1 字符串使用比较运算符
- 数字和字符串做 == 运算符结果是False,除了 == 运算符以外的逻辑运算时,会直接报错。
- 如果两个字符串进行比较,会将每个字符都转换成对应得编码,然后逐一进行比较。
3.4 逻辑运算符
运算符 | 逻辑表达式 | 描述 |
---|---|---|
and | x and y | 只要有一个运算数是False,结果就是False;只有所有的运算数都是True时,结果才是True;做取值运算时,取第一个为False的值,如果所有的值都是True,取最后一个值 |
or | x or y | 只要有一个运算数是True,结果就是True;只有所有的运算数都是False时,结果才是False;做取值运算时,取第一个为True的值,如果所有的值都是False,取最后一个值 |
not | not x | 布尔“非”,如果x为True,返回False;如果x为False,返回True |
a = 34
b = 12
print((a > b) and (b > 10) and (a > 30) and (a > 50))
print((a > b) and (b > 10) and (a > 30) and (a < 50))
print(a and b and 'hello' and 0 and 123)
print(a and b and 'hello' and 123 and 'hi')
print((a > 50) or (b < 10) or a > b or (a == b))
print((a > 50) or (b < 10) or a < b or (a == b))
print(0 or None or a or '')
print(0 or "" or '' or None)
a = 34
a > 10 and print('hello world') #hello world
a < 10 and print('hello world') #False
a >10 or print('你好世界')#True
a <10 or print('你好世界')#hello world
3.5 位运算符(了解)
安位运算符是把数字看作二进制来进行计算的。
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
运算 | 描述 | 示例 |
---|---|---|
& | 按位与运算:参与运算的两个值,如果两个相应位都为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 |
练习:
- 使用位运算,获取到十六进制颜色
0xF0384E
的RGB值,以十进制形式打印输出。
color = 0xF0384E
red = color >> 16
green = (color & 0x00FF00) >> 8
blue = color & 0x0000FF
3.6 运算符的优先级
运算符 | 描述 |
---|---|
** | 指数 (最高优先级) |
~ + - | 按位翻转, 一元加号和减号 (最后两个的方法名为 +@ 和 -@) |
* / % // | 乘,除,取模和取整除 |
+ - | 加法减法 |
>> << | 右移,左移运算符 |
& | 位 ‘AND’ |
^ | | 位运算符 |
<= < > >= | 比较运算符 |
<> == != | 等于运算符 |
= %= /= //= -= += *= **= | 赋值运算符 |
is ,is not | 身份运算符 |
in ,not in | 成员运算符 |
not>and>or | 逻辑运算符 |
在以后的实际开发中,如果有多种运算符进行混合运算时,强烈建议使用小括号来手动的控制运算符的优先级!