一、运算符
python支持: 数学运算符、比较运算符、逻辑运算符、赋值运算符、(位运算符)
1.数学运算符: +(加号),-(减号),(乘号),/(除号),//(整除),%(取余),*(幂运算)
a.其中+、-、*、/和数学中的加减乘除一模一样
print(10+20)
print(12.6+5)
print(100-110)
print(2*3)
print(5/2)
// (整除),数字1 // 数字2 --> 让数字1除以数字2,结果只取整数部分
print(5 // 2) # 2
print(6.3 // 3) # 2.0
练习,获取数字 234 中的百位上的数 2
print(234 // 100)
b.%(取余),求余数
print(5 % 2) # 求5除以2的余数
print(10 % 4)
应用一:获取一个数的个位数
print(234 % 10)
应用二:判断一个数的奇偶性,让这个数对2取余,然后看结果是0(偶数)还是1(奇数)
print(10 % 2, 23 % 2, 22 % 2, 3 % 2)
d.**(幂运算),x ** y --> 求x的y次方
print(2 ** 3)
print(10 ** 4)
print(16 ** 0.5) # x ** 0.5 == x ** (1/2) == x开平方
print(8 ** (1/3)) # 8开立方
age = 18
print(age + 10)
注意:运算符的运算对象不一定非得是数据,也可以是存数据的变量
2.比较运算符:>(大于), <(小于), ==(等于), !=(不等于) , >=(大于等于) , <=(小于等于)
所有的比较运算符的结果都是布尔值
print(10 > 20) # False
print(10 < 20) # True
print(10 == 20) # False
print(10 == 10) # True
print(10 != 20) # True
print(10 != 10) # False
print(10 >= 20) # False
print(20 >= 20) # True
age = 18
print('是否成年:', age >= 18)
补充: is的使用
一个变量有三要素,分别是:类型(变量中存储的数据的类型)、值(变量存储的数据)、地址(变量真正存储的内容,数据的地址)
类型 - type(变量)
值 - 直接使用变量,就是使用值
地址 - id(变量)
== 和 is 的区别
==: 判断的是值是否相等 (应付面试!!)
is: 判断的是地址是否相等
num = 100
print(type(num), num, id(num))
list1 = [1, 2]
list2 = [1, 2]
list3 = list1 # 用一个变量给另一个变量赋值的时候,是将变量中存储的数据的地址赋给另外一个变量
print(list1, list2)
print(id(list1), id(list2))
print(list1 == list2, list1 is list2) # True False
print(list1 == list3, list1 is list3) # True True
3.逻辑运算符:and(逻辑与), or(逻辑或), not(逻辑非)
逻辑运算符的运算对象和运算结果都是布尔值
a.值1 and 值2 --> 如果两个都为True结果就是True,否则结果是False;相当于生活逻辑中的‘并且’
True and True -> True
False and True -> False
True and False -> False
False and False -> False
应用:要求多个条件同时满足的时候,就使用逻辑与运算
短路操作:如果第一个条件是False,就不会再去判断第二个条件,直接让整个与运算的结果是False
练习:能拿奖学金的条件是成绩必须90分以上并且测评分不能低于95
grade = 91
score = 95
print('是否能拿奖学金:', grade > 90 and score >= 95)
b.值1 or 值2 --> 如果两个都为False结果才是False,否则结果是True; 相当于生活逻辑中的'或者'
True or True -> True
False or True -> True
True or False -> True
False or False -> False
应用:要求多个条件只要有一个条件满足,就是使用逻辑或运算
短路操作:如果第一个条件是True,就不会再去判断第二个条件,直接让整个或运算的结果是True
练习:如果考试成绩低于60分,或者上课不听讲就要降班
grade = 70
is_not_in_class = True # True代表在班级,False代表不在班级
print('是否降班:', grade < 60 or is_not_in_class)
c.not 值1 --> 对值1进行否定/取反(不是、否定)
not True -> False
not False -> True
应用:否定某个条件
练习: 年龄不小于10
age = 20
print(not age < 10)
4.赋值运算符:=,+=,-+,=,/=,//=,%=,*=
所有的赋值运算符,要求赋值符号的左边必须是变量;右边是必须有结果的(是值)
a. 变量 = 结果 --> 将结果赋给变量
num = 100
num2 = num
变量给变量赋值,赋的是变量的地址
b.+=,-+,=,/=,//=,%=,*=
复合赋值运算符要求赋值符号的左边除了是变量以外,还要求这个变量已经被赋过值
变量 += 数字 --> 变量 = 变量 + 数字(让变量原来的值加上指定的数字以后的新值再重新赋给变量)
num3 = 2
num3 += 10 # num3 = num3 + 10 = 2 + 10
print(num3) # 12
num3 -= 3 # num3 = num - 3 = 12 - 3
print(num3) # 9
5.运算符的优先级
数学运算符 > 比较运算符 > 逻辑运算符 > 赋值运算符
数学运算符中: ** > *,/,%,// > +,-
优先级高的先算,优先级低的后算.如果有(),先算()里面
布尔中True == 1, False == 0
二、数字类型
数字类型:int float, complex, bool
1.整型(int):包含所有的整数,支持十进制、二进制、八进制和十六进制
num0 = 123 # 十进制直接写十进制数字
num1 = 0b110101 # 二进制:0b+二进制数
num2 = 0o127 # 八进制:0o+八进制数
num3 = 0x89af # 十六进制:0x+十六进制数
print(num0, num1, num2, num3) # 打印的是这个数的十进制
print('十进制', 123)
print('二进制', bin(123))
print('八进制', oct(123))
print('十六进制', hex(123))
print(0b1111011+2)
2.浮点型(floa):包含所有的小数,支持科学计数法
num1 = 12.5
num2 = 3e2
print(num2) # 代表 3乘以10的2次方
num3 = 1.25e2
print(num3)
3.布尔(bool): 值只有True == 1和False == 0
True还是表示真、肯定,False还是表示假、否定
num1 = True + 10
print(num1, True == 1, False == 0)
4.复数(complex):实部+虚部j, 注意:j前面必须有数字,不能省略
三、字符串(部分)
1.认识字符串(str)
通过单引号或者双引号括起来的字符集(文本)就是字符串
str1 = 'abc'
str2 = "abc123"
2.字符串类型(str)
str是python自己提供的一种容器型数据类型,一个字符串中可以存储多个字符
什么是字符:python中只有字符的概念没有字符类型,如果在python中要表示一个字符,用一个长度是1的字符串来表示
字符串不可变但是有序,不可变指的是字符的值和字符串的长度不可变,有序指的是每个字符在字符串中的位置是确定的(字符串'abc'和字符串'bac'是不一样的)
3.字符串中的字符
a.普通字符:包含一般的字母,数字,符号,其他文字,例如:'a','G','1','+','^','?','好'
b.转义字符:通过在一些特定的字母前加,来表示特殊的功能或者意义,这样的字符就是转义字符.
\n - 换行 ' - 表示一个单引号 " - 表示一个双引号
\ - 表示一个反斜杠 \t - 表示一个tab建
注意:1.没有阻止转义的时候,一个转义字符的长度是1
2.可以在字符串的最前面加r/R,来阻止转义.(阻止字符串中所有的转义字符转义)
c.编码字符:在字符串中以'\u1234',这儿的1234表示四位十六进制编码值
str4 = 'abc\n123'
str5 = 'hello\'A'
str6 = "he\"llo'A"
str7 = '\\ahello\\npython'
print(str4)
print(str5)
print(str6)
print(str7)
# 阻止转义
str8 = r'\t姓名:小白\n\t年龄:18'
print(str8)
str9 = '你好\u4e00'
print(str9)
4.字符编码
计算机在存储数据的时候只能存数字数据,而且存的是数字的二进制的补码
10 -> 转换成二进制 -> 求补码(存)
字符的编码就是为了将字符存储到计算机中,给每个字符对应的一个固定的数字,这个数字就是这个字符的编码
目前计算机采用的编程方式有两种,分别是ASCII码表和Unicode码表,python中采用的是Unicode编码表。
ASCII码是采用一个字节对字符进行编码(总共128个字符)
Unicode码包含ASCII码,采用两个字节对字符进行编码,包含了世界上所有的语言和符号,又称万国码
- 小写字母的编码范围(a-z):97 - 122
- 大写字母的编码范围(A-Z):65 - 90
- 中文编码范围; 0x4e00 ~ 0x9fa5
字符编码相关的函数:
a.chr(编码值) - 获取编码对应的字符
b.ord(字符) - 获取字符的编码 (以十进制的形式返回)
print(chr(0x4e55))
print(ord('李'), ord('厅'), ord('康'))
print(hex(ord('李')), hex(ord('厅')), hex(ord('康')))