一、链式赋值_系列解包赋值_常量
- 链式赋值
用于将同一个对象赋值给多个变量。
x = y = 123
- 系列解包赋值
系列数据赋值给对应相同个数的变量(个数必须保持一致)
a,b,c = 4,5,6
【常用操作】使用系列解包赋值实现变量交换
a,b = 1,2
a,b = b,a
print(a,b)
- 常量
Python不支持常量,即没有语法规则限制改变一个常量的值,只能约定常量的命名规则,以及在程序逻辑上不对常量值作出修改。
MAX_SPEED = 120
print(MAX_SPEED) #实际上式可以改的,但是在逻辑上不能更改。
二、内置数据类型_基本算术运算符
每个对象都有类型,Python中最基本的内置数据类型:(后面还可以自定义)
- 整型
整数 123 - 浮点型
小数,3.14或科学计数法314e-2 - 布尔型
True/False
- 字符串型
数字
Python支持整数和浮点数,可以对数字做如下运算:
【注1】0不能作除数,会产生异常!
【注2】使用divmod函数同时得到商和余数
divmod(被除数,除数)
三、整数_不同进制_其他类型转换成整数
整数
- Python中除了10进制,还有其他3种进制:
# 1. 二进制
0b/0B: 0B1010
# 2. 八进制
0o/0O: 0o10
# 3. 十六进制
0x/0X: 0xff
使用int()实现类型转换
- 浮点数直接舍去小数部分
- 布尔值True=1,False=0
- 字符串符合整数格式(浮点数格式不行)则直接转换成对应整数,否则报错。
自动转型
浮点数和整数混合运算时,表达式结果自动转型成浮点数。
整数的大小
Python3中,int可以存储任意大小的整数,long被取消。Python3中可以做超大数的运算,而不会造成“整数溢出”,这也是Python特别适合科学运算的特点。
四、浮点数_自动转换_强制转换_增强赋值运算符
浮点数
浮点数float
.浮点数使用axb^10
形式的科学计数法表示
类型转换和四舍五入
- 类似于
int()
,使用float()
将其他类型转化成浮点数 - 整数和浮点数混合运算时,表达式结果自动转型成浮点数。
round()
可以返回四舍五入的值【但不会改变原来的值,而是产生新的值】
增强型运算符
普通的运算符和赋值符=结合构成“增强型运算符”。
五、时间表示_unix时间点_毫秒和微秒_time模块
时间表示
计算机中时间的表示是从“1970年1月1日 00:00:00”开始,以毫秒(1/1000s)进行计算。也把这个时间点称为“Unix时间点”。【往前为正,往后为负】
Python中可以通过time.time()
获得当前时刻,返回的值时以s为单位,带微秒(1/1000ms)精度的浮点值。
>>> import time
>>> s = time.time()
>>> s
1612095181.4699886
【tiny test】
# 获得秒数
>>> s = int(time.time())
>>> s
1612095796
# 获得分钟数
>>> minutes = s //60
>>> minutes
26868263
# 获得小时数
>>> hours = minutes//60
>>> hours
447804
# 获得天数
>>> days = hours//24
>>> days
18658
# 获得年数(闰年没有考虑)
>>> years = days//365
>>> years
51
六、【总结练习】多点坐标绘出折线图计算两点距离
import turtle
import math
turtle.width(5)
# 定义多点坐标,绘出折线,并计算起点和终点的距离
x1,y1 = 100,200
x2,y2 = 310,-234
x3,y3 = -425,215
x4,y4 = 342,-263
turtle.penup()
turtle.goto(x1,y1)
turtle.pendown()
turtle.goto(x2,y2)
turtle.goto(x3,y3)
turtle.goto(x4,y4)
distance = math.sqrt((x1 - x4)**2+(y1-y4)**2)
turtle.write(distance)
七、布尔值_比较预算_逻辑运算符_短路问题
布尔值
Python3 中直接将True和False定义成了关键字,但是它们的本质还是1 和 0 .甚至可以和数字相加。
比较运算符
逻辑运算符
注意逻辑或和逻辑与部分的说明!!!
八、同一运算符_整数缓存问题
同一运算符
同一运算符用于比较两个对象的存储单元,实际比较的是对象的地址。
【注意】is与==的区别:
is 用于判断两个变量引用对象是否为同一个,即比较对象的地址
== 用于判断变量引用的值是否相等,默认调用对象的_eq_()
方法
整数缓存问题(影响使用同一运算符的结果)
- 在命令行中执行的时候,Python仅仅对比较小的整数对象及进行缓存
[-5,256]
,而并非缓存所有对象 - 在Pycharm或者保存为文件执行时,缓存范围不同,因为解释器进行了一部分优化,范围是
[-5,任意正整数]
Summary
- is比较两个对象的id值是否相等,是否指向同一个内存地址
- == 比较两个对象的内容是否相等,值是否相等
- 小整数对象在全局解释器范围内被放入缓存供重复使用
- is 运算符 效率更高(因为 == 调用了_eq_()方法),在变量和None进行比较时,要用is(None没有值)
九、字符串_unicode字符集_三种创建字符串的方法_len()
字符串
- 字符串的本质是字符序列。Python的字符串是不可变的,我们无法对原字符串做任何修改。但是可以将字符串的一部分复制到新创建的字符串,达到“看起来修改”的效果。
- Python不支持单字符类型,单字符也是作为一个字符串使用的。
字符串的编码
Python3支持Unicode,可以表示世界上任何书面语言的字符。Python3默认16位Unicode编码。ASCII是Unicode子集
- 使用内置函数
ord()
可以把字符转换成Unicode编码 - 使用内置函数
chr()
可以把十进制数字转换成对应的字符
引号创建字符串
- 可以通过单引号或双引号创建字符串。【使用两种引号的好处是可以创建本身就包含引号的字符串,而不是用转义字符】
- 连续三个单引号或三个双引号,可以帮助我们创建多行字符串
不用print在控制台输出不同
空字符串和len函数
- Python允许空字符串的存在,不包含任何长字符且长度为0
len()
用来计算字符串包含多少字符
转义字符
字符串拼接
- 可以使用+将多个字符串拼接起来
【1】如果两边都是字符串,则拼接(形成一个新的对象)
【2】如果两边都是数字,则加法运算
【3】如果两边类型不同,则抛出异常 - 可以将多个字面字符串直接放到一起实现拼接
字符串复制
使用*
可以实现字符串复制
不换行打印
调用print
时会自动打印一个换行符。但有时不想换行,可以通过参数end="任意字符串"
,实现末尾添加任何内容
print("dxe",end="##")
print("sdfa")
print("sdf",end="")
从控制台读取字符串
可以使用input()
从控制台读取键盘输入内容
使用str()实现数字转型字符串
使用print()函数时,解释器自动调用了str()将非字符串的对象转成了字符串。
使用[]提取字符串
字符串的本质是字符序列,可以通过在[]里指定偏移量,提取该位置的单个字符。
- 正向搜索:最左侧第一个字符偏移量是0,依次+1,直到
len(str)-1
- 反向搜索:最右侧第一个字符偏移量是-1,依次-1,直到
-len(str)
【超出范围会报错】
replace实现字符串替换
字符串是不可改变的,通过[]可以获取特定位置的字符,但是不能改变字符串,如果改变会报错。
字符串不可改变,只能通过创建新的字符串来实现。实际上是新创建了一个字符串对象然后更改了变量str的指向。
字符串切片slice操作
切片操作可以快速提取字符串,标准格式如下:
str[start:end:step]
# 起始 : 终止 :步长
常见典型操作:
要满足起始和终止的含义啊!
【注意】slice操作时,起始偏移量和终止偏移量不在[0,len(str)-1]
这个范围也不会报错,起始小于0,当成0处理;终止大于len(str)-1,当成-1
split分割和join合并
- split()可以基于指定分隔符将字符串分隔成多个子字符串(存储到列表中)。如果不指定分隔符,则默认空白字符(换行符/空格/制表符)。
- 【to前面也会被记录成一个空字符串】
直接使用效果如下: - join()用于将一系列子字符串连接起来(注意别忘了双引号)
【join通常和列表一起使用】
拼接字符串要点:
使用字符串拼接符+会产生新的字符串对象,因此不推荐使用+来拼接字符串,推荐使用join函数,因为join函数在拼接字符串之前会计算所有字符串的长度,然后再逐一拷贝,仅新建一次对象。
# 测试时间的内容就不写了,记录一下循环拼接字符串的过程
# 使用+
a = ""
for i in range(100):
a += "abc"
# 使用join
l = []
for i in range(100):
l.append("abc")
string = "".join(l)
字符串驻留机制和字符串比较
字符串驻留:仅保存一份相同且不可变的字符串的方法,不同的值被存放在字符串驻留池中。Python支持字符串驻留机制,对于符合标识符规则【数字、字母、下划线】的字符串会启用字符串驻留机制。
但如果通过字符串拼接重建则不同:(还是新建)
但是初始化的时候这样ok
成员操作符
in/not in关键字,判断某个字符(子字符串)是否存在于字符串中
字符串常用方法汇总
- 常用查找方法
- 去除首尾信息
【经常用来去除首尾空格!只去除首尾空格不去除中间的部分】
strip() # 去除首尾指定信息
lstrip() # 去除左边指定信息
rstrip() # 去除右边指定信息
- 大小写转换
如果是大写转换成小写,如果是小写转换成大写:
- 格式排版
以下三个函数用于实现字符串的排版:
center() # 居中左右填充
ljust() # 左对齐
rjust() # 右对齐
- 其他方法
isalnum() # 检测是否为字母或数字
isalpha() #检测字符串是否只由字母/汉字组成
isdigit() # 检测字符串是不是只由数字构成,不是检测数字,只能包含0-9
isspace() # 是否为空白符(3个)
isupper() # 是否为大写字母
islower() # 是否为小写字母
- 字符串的格式化
【1】format的基本用法
基本语法是通过{}
和:
来代替之前的%。format函数可以接收不限个参数,位置可以不按顺序来。通过{index}/{parament name}
,直接映射参数值,实现对字符串的格式化,非常方便。
【2】填充与对齐
填充常跟对齐一起使用。
后面带宽度
^ 居中
< 左对齐
> 右对齐
: 后面带填充的字符,只能是一个字符,不指定默认空格