变量和运算符
1.快捷键
ctrl + / - 添加注释和取消注释
ctrl + s - 保存
ctrl + c - 拷贝
ctrl + v - 粘贴
ctrl + a - 全选
ctrl + x - 剪切
ctrl + z - 撤销
ctrl + shift + z - 反撤销
按住shift再点击鼠标 - 选中部分
按住alt/option再点鼠标 - 让界面出现多个光标
2.变量
1.什么是变量
变量是在程序开辟空间存储数据用的
python中所有的变量中存放的都是地址,相当于指针。
2.怎么声明变量
1)语法:
变量名 = 值
2)说明:
变量名 - 程序员自己命名
(要求)是标识符,不能是关键字
(规范)要采用PEP8命名规范 - 变量名中所有的字母都小写,如果变量名由多个词组成,单词之间用下划线隔开
见名之义 - 看见变量名大概知道变量中存储的是什么数据
= : 赋值符号,将右边的值赋给左边的变量
值 :任何有结果的表达式,可以是具体的数据,也可以是赋值过的变量,也可以是运算表达式
a.同一个变量可以存储不同类型的值
变量必须先声明/赋值在使用
b.同时声明多个变量,赋相同的值:变量名1 = 变量名2 = .... = 值
c.同时声明多个变量,赋不同的值:变量名1 , 变量名2 = .... = 值1,值2,...
d.声明变量和给变量赋值的原理 ※
先在内存中开辟空间存储数据(内存空间的大小由数据的大小动态地分配)然后再将保存数据的内存空间的地址赋给变量
用一个变量给另一个变量赋值的时候,实质是把变量中的地址赋给新的变量
num3 = 100
print(type(num3))
print(id(num3)) #获取变量中数据在内存中的地址
num4 = num3
print(id(num4))
# 指向同一地址的变量在一个发生改变时,另一个也会相应的产生改变
list1 = [1,2,3,4,5]
list2 = list1
list1.append(6)
print(list1)
print(list2)
3.运算符
1.逻辑运算符:and(逻辑与运算),or(逻辑或运算),not(逻辑非运算)
所有的逻辑运算符的运算对象是布尔,结果也是布尔。
1)and
a.运算规则:两个都为True,结果才为True。只要有一个是False结果就是False。
b.什么时候用:当希望多个条件同时满足的时候,就用and将多个条件连接。and相当于生活中的并且
2)or
a.运算规则:两个都为False,结果才为False。只要有一个是True结果就是True。
b.什么时候用:当希望多个条件只要有一个满足的时候,就用or将多个条件连接。or相当于生活中的或者
3)not
a.运算规则:True变False,False变True
b.什么时候用:对某个条件进行否定
4)短路操作
逻辑与运算的短路操作:当and前面的表达式的值是false的时候,程序不会再去执行后面的表达式。
逻辑或运算的短路操作:当or前面的表达式的值得True的时候,程序不会再去执行后面的表达式。
#练习:
num = 8
# 1)判断一个数是否能被2或者5整除
print(str(num)+'是否能被2或者5整除:',num % 2 == 0 or num % 5 == 0)
# 2)判断一个数能否同时被2或5整除
print(str(num)+'能否同时被2或者5整除:',num % 2 == 0 and num % 5 == 0)
# num % 10 == 0 同时除最小公倍数也可以实现
# 3)判断一个数是否是3或者7的倍数,并且这个数的末尾不是3
print(str(num)+'是否是3或者7的倍数,并且这个数的末尾不是3:',(num % 3 == 0 or num % 7 == 0 ) and num % 10 != 3)
2.赋值运算符:=,+=, -=, *=, /=, %=, //, **=
不管是什么样的赋值运算符,最终的操作都是给变量赋值,所以赋值运算符的左边必须是变量
1)= :将右边的值赋给左边的变量
2)复合的赋值运算符:先将赋值符号左边变量中的值取出来,然后进行指定的预算后,最后将运算结果再重新赋值给左边的变量
注意:复合的赋值运算符的左边必须是已经赋值过得变量
3.运算符优先级
1)运算的优先级
数学 > 比较 > 逻辑 > 赋值
2)数学运算符优先级
** > *,/,//,% > +,-
3)如果有(),先算()里的
4.位运算
位运算操作的是数字的补码的每一位;位运算因为是直接操作计算机空间的每一位,所以执行效率要比一般的运算要高
1.位运算符:&(按位与运算),|(按位或运算),^(按位异或),~(按位取反),<<(左移),>>(右移)
1)按位与
数字1 & 数字2 -> 两个数字补码上相同位置的数,如果都是1结果就是1,只要有一个是0结果就是0
2)按位或
数字1 | 数字2 -> 两个数字补码上相同位置的数,如果都是0结果就是0,只要有一个是1结果就是1
3)按位取反
~数字 -> 将数字补码上每一位的值由0变成1,由1变成0
4)按位异或
数字1 ^ 数字2 -> 两个补码上相同位置的值,如果相同结果是0,不同结果是1
特点:一个数异或同一个数两次,结果就是这个数本身
5)左移
数字 << N -> 让数字的补码整体左移N位,低位用0补充 -> 数字 x (2**N) 左移一位乘2
6)右移
数字 >> N -> 让数字的补码整体右移N位,正数高位补0,负数高位补1 -> 数字 //(2**N) 右移一位除2
# 右移除2是向下取整
print(9 >> 1)
print(-5 >> 1)
※ //运算取整时保留整数的下界,int则是剪去小数部分,只保留前面的整数,即向零取整,round函数遵循四舍五入的法则
2.应用
1)乘2的次方或者整除2的次方的操作 (<<, >>)
2)数字 & 1 == 0 -> 偶数 ; 数字 & 1 == 1 -> 奇数 (与数字的正负无关)