一 、运算符
python支持: 数学运算符、比较运算符、逻辑运算符、赋值运算符、(位运算符)
1. 数学运算符:(加)+, (减)-, *(乘),/(除), //(整除), %(取余), **(幂运算)
其中+ - * / 和数学中的加减乘除一样
print(10 + 20)
print(12.6 + 5)
print(100 - 110)
print(2 * 3)
print(5 / 2)
//b. (整除),结果只取整除部分,数字1除以数字2--> ,结果只取整数部分
print(5 // 2) # 2
print(6.3 // 3) # 2.0
练习,获取数字234中的百位上的数 2
print(234 // 100)
c. %(取余),求余数
print(5 % 2) # 求5除以2的余数
print(10 % 4)
应用一: 获取一个数的个位数
print(234 % 10) # 4
应用二: 判断一个数的奇偶性,让这个数对2取余数,看见结果是0(偶数)还是1(奇数)
print(20 % 2, 23 % 2 )
d. (幂运算),xy--> 求x的y次方
print(2**3)
print(10 4)
print(16 ** 0.5) # 开方 x 0.5 ==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)
print(list1 == list3, list1 is list3)
num1 = 100
num2 = 100
print(id(num1), id(num2))
str1 = 'abc'
str2 = 'abc'
print(id(str1),id(str2))
数字和字符串比较特殊,地址一样
3.逻辑运算符:and(逻辑与运算), or(逻辑或), not(逻辑非运算)
逻辑运算符的运算对象和运算结果都是布尔值
值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 代表在不班级,否则在
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 # num = num3 +10
print(num3)
num3 -= 3 # num3 = num3 - 3 =12 - 3
print(num3) # 9
5 运算符的优先级
数学运算符> 比较运算符 > 逻辑运算符 > 赋值运算符
数学运算符中:**> *, /, %,// > +, -
优先级高的先算,优先级低的后算。如果有(),先算()里面的
练习
布尔中的True == 1 ,False == 0
print(19 + 20 > 6**2 +4 or 10 + 3 < 3 * 3) # False
19 + 20 > 36 + 4 or 10 + 3 < 9
39 > 40 or 13 < 9
False or False
False
二、
数字类型: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. 浮点型(float):包含所有的小数,支持科学计数法
num1 = 12.5
num2 = 3e2 # 代表 3乘以10 的2次方
print(num2)
num3 = 1.25e2
print(num3)
3. 布尔(bool): 值只要True == 1 和False == 0
num1 = True + 10
print( num1, True == 1)
"""
- 复数(complex):实部 + 虚部j;注意:j 前面必须有数字,不能省略
"""
三、
"""
- 认识字符串(str)
通过单引号或者双引号括起来的字符集(文本)就是字符串
str1 = 'abc'
str2 = 'abc123'
"""
2. 字符串类型(str)
str是Python 自己提供的一种容器型的数据类型,一个字符串中可以存储多个字符
什么是字符:pyhton 只有字符的概念,没有字符的类型,如果在python中药表示一个字符,
用一个长度是1的字符串来表示
num = 100
字符串不可变,但是有序,不可变指的是字符的值和字符串的长度不可变,有序指的是每个字符在字符串中的位置是确定的
字符串"abc和字符串"bac是不一样的
3 . 字符串中的字符
a. 普通字符:包含一般的字母、数字、符号、文字、其他文字,例如"a, 'G, "1, '+ ."叫
data = 100
data = '100'
str3 = "skhfk号"
b. 转义字符: 通过在特定的字母前面加/,来表示特殊功能或者意义,这样的字符就是转义字符。
str4 = 'abc\n123' # \n -- 换行
print(str4)
str5 = '\thelo'A' # '---表示一个单引号
print(str5)
str6 = "hello'A"
print(str6) # " ---表示一个双引号
str7 = '\ahello\npyhton'
print(str7) # \ ---表示一个反斜杠
\n -- 换行
' -- 表示一个单引号
" -- 表示一个双引号
\ -- 表示一个反斜杠
\t -- 表示一个tab键
以上统称转义字符,适合所有语言
注意:1没有阻止转义的时候,一个转义字符的长度是1 例如 \t 长度是1
2可以在字符串的最前面加r/R,来阻止转义。(阻止字符串中所有的转义字符转义)
阻止转义
str8 = r'\t姓名:小白\n\t年龄:18'
print(str8)
c. 编码字符: 在字符串中用'\u' + 四位十六进制编码值表示一个字符
'\u1234', 这儿的1234是十六进制的
str9 = '你好\u4e00\uaaaa'
print(str9)
4 字符编码
计算机在存储数据的时候只能数字数据,而且存是数字的二进制补码
10 -> 转换成二进制 -> 求补码(存)
字符的编码就是为了将字符存储到计算机中,给每个字符对应的一个固定的数字,这个数字就是这个字符的编码
目前计算机采用的编码方式有两种,分别是ascii 码和unicode 码表。python 中采用的是unicode编码
ascii码是采用一个字节对字符进行编码9总共128个字符)
unicode 码包含ascii码,采用两个字节对字符进行编码,包含世界上所有的语言和符号,又称万国码
小写字母的编码范围:(a-z) 97-122
大写字母的编码范围:(A-Z) 65--90
中文编码范围: 0x4e00 ~ 0x 9fa5
字符编码相关的函数
a. chr(编码值) - 获取编码对应的字符
b. ord(字符) - 获取字符的编码(以十进制形式返回)
print(chr(0x4e90))
print(ord('杨'), ord('浩'))