常用运算符:算数运算符 比较运算符 逻辑运算符 赋值运算符 成员运算符 身份运算符 位运算符(为二进制运算准备的运算符)
一,赋值运算符:
示例:
a = 1
b = 2
c = 3
d = 4
e = 5
f = 6
g = 7
#加法
a += 1
print(a)
str = 'cbd'
str += 'bck'
print(str)
#减法
b -= a
print(b)
#乘法
c *= 4
print(c)
#除法
d /= 20
print(d)
#取模
e %= 3
print(e)
#幂赋值
f **= 3 #6的3次方
print(f)
运行结果:
二,成员运算符 与 身份运算符
1,成员运算符:(序列 数组 集合)
在指定的序列找到值返回True 否则返回False
关键字:in
在指定的序列没有找到值返回True 否则返回False
关键字:not in
sheet = ['小李','小王','小兰']
if ('小兰' in sheet):
print('小兰在数组里')
else:
print('小兰不在数组里')
if ('小兰' not in sheet):
print('小兰在数组里')
else:
print('小兰不在数组里')
运行结果:
2,身份运算符:(涉及到引用对象概念)
is 判断 两个变量是不是引用一个对象
is not 判断两个变量是不是引用不同对象
示例:
a = 4
b = a
c = 4.0
print(a is c)
print(a == c)#数值比较
print(a is c)#对内存地址进行比较,a与c并不指向同一块内存区域
运行结果:
三,位运算符:对二进制数据进行运算
二进制:通过0和1两个数码来代表的数据 例如:100101
二进制算法:进位规则 逢二进一 借位规则 借一当二
示例:100101 + 1 =100110 111111 + 1 = 1000000
十进制与二进制进行转换:
转换规则:从右到左用每位数乘以2的N次方(0开始)后累加
示例:
将1101转换为十进制:
个位:1*2^0 = 1
十位:0*2^1 = 0
百位:1*2^2 = 4
千位:1*2^3 = 8
1+0+4+8 =13
十进制转二进制:用十进制对2取余,将余数放在二进制左侧
示例:
将47转换为二进制:
47/2=23余1
23/2=11余1
11/2=5余1
5/2=2余1
2/2=1余0
1/2=0余1
二进制:101111
位运算符:
示例:
a = 60 #60的二进制:00111100
b = 13 #13的二进制:00001101
c = 0
#& 与
#按照位来进行上下运算
#00001100 = 12
c = a & b
print('a & b:',c) #返回12
#1 或
#00111101 = 61
c = a | b
print('a | b:',c) #返回61
#^ 异或
c = a ^ b
#00110001 = 49
print('a ^ b:',c) #返回49
#~ 取反
#说明:对于取反 有额外的要求:如果最左侧的数值为1 则代表是一个负数,要在原始数值前方增加负号,同时对原本已经取反的数值 再次取反;之后在基础上+1;0的话代表正数;
c = ~ a
#1> 11000011 对a数值取反
#2> -(~11000011 + 1) 再次取反 规则固定不变
#3> -(~00111100 + 1)
#4> -00111101 = -61最终结果
print('~ a:',c) #返回-61
#<< 左移
# a=00111100
#左移3为:00111100000 = 480
c = a << 3
print('a << 3:',c)
#>> 右移
# a=00111100
#右移3为:00000111 = 7
c = a >> 3
print('a >> 3:',c)
注意:对于取反 有额外的要求:如果最左侧的数值为1 则代表是一个负数,要在原始数值前方增加负号,同时对原本已经取反的数值 再次取反;之后在基础上+1;0的话代表正数;