01-运算符
python支持数学运算符、比较运算符、逻辑运算符、赋值运算符、(位运算符)
1、数学运算符
包括:+(加法),-(减法),(乘法),/(除法),*(幂运算),//(整除),%(取余)
示例:
a.其中+、 -、 *、 / 和数学中的加减乘除一模一样
print(10 + 20) # 30
print(12.6 + 5) # 17.6
print(100 - 110) # -10
print(2 * 3) # 6
print(5 / 2) # 2.5
b. //(整除),数字1 // 数字2 --> 让数字1除以数字2,结果只取整数部分
print(5 // 2) # 2
print(6.3 // 3) # 2.0
c. %(取余),求余数
print(5 % 2) # 求5 除以2 的余数
print(10 % 4)
d. **(幂运算),X ** y --> 求X的y次方
print(2 ** 3, 10 ** 3)
print(9 ** 0.5) # X ** 0.5 == X ** (1/2) == X开平方
print(10 ** 0.5) # X ** 0.5 == X ** (1/2) == X开平方
print(8 ** (1/3)) # X ** (1/3) == X开立方
注意1:上面语句中# 后面内容是对前面内容的结果或者解释
注意2:
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
补充: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
num1 = 100
num2 = 100
print(id(num1), id(num2))
str1 = 'abc'
str2 = 'abc'
print(id(str1), id(str2))
效果:
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
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
c. not 值1 --> 对值1进行否定/取反 (不是、否定)
not True -> False
not False -> True
应用:否定某个条件
4. 赋值运算符:=, +=, -+, *=, /=, //=, %=, **=
所有的赋值运算符,要求赋值符号左边必须是变量;右边必须是有结果的(是值)
a. 变量 = 结果 --> 将结果赋给变量
num = 100
num2 = num 注意: 变量给变量赋值,赋的是变量的地址
b. +=, -+, *=, /=, //=, %=, **=
复合赋值运算符要求赋值符号的左边除了是变量以外,还要求这个变量已经赋过值
变量 += 数字 --> 变量 = 变量+ 数字 (让变量原来的值加上指定的数字以后的新值再重新赋给变量)
num3 = 2
num3 += 10 # num3 = num3 + 10 = 2 + 10
print(num3) # 12
num3 -= 3 # num3 = num3 -3 = 12 - 3
print(num3) # 9
5. 运算符的优先级
数学运算符 > 比较运算符 > 逻辑运算符 > 赋值运算符
数学运算符中:** > *, /, %, // > +, -
优先级高的先算,优先级低的后算。如果有(),先算()里面
布尔中True == 1, False == 0
print(True + 10, False + 10) -->11,10
02-数字类型: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) --> 300.0
num3 = 1.25e2
print(num3) --> 125.0
3. 布尔(bool):值只有True == 1 和False == 0
Ture还是表示真、肯定
False还是表示假、否定
num1 = True + 10
print(num1, True == 1, False == 0)
4.复数(complex):实部+虚部j,注意:j前面必须有数字,不能省略
03-字符串
1. 认识字符串
通过单引号或者双引号括起来的字符集(文本)就是字符串
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是四位十六进制编码值,表示一个字符
示例:
普通字符和转义字符
data = 100
data = '100'
str3 = 'abc234好'
str4 = 'abc\n123'
str5 = '\thello'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\u4e11'
print(str9)
效果:
4. 字符编码
计算机在存储数据的时候只能存数字数据,而且存的是数字的二进制的补码
10 -> 转换成二进制 -> 求补码(存)
字符的编码就是为了将字符存储到计算机中,给每个字符对应一个固定的数字。这个数字就是这个字符的编码
目前计算机采用的编码方式有两种,分别是ASCII码表和Unicode码表。python中采用的是Unicode编码
ASCII码是采用一个字节对字符进行编码(总共有128个字符)
Unicode码包含ASCII码,采用两个字节对字符进行编码(总共有32768个字符),包含了世界上所有的语言和符号,又称万国码
小写字母的编码范围(a-z):97 - 122
大写字母的编码范围(A-Z):65 - 90
中文编码范围:0x4e00 - 0x9fa5
字符编码相关的函数:
a. chr(编码值) - 获取编码对应的字符
b. ord(字符) - 获取字符的编码(以十进制的形式返回)