一、异常
1. 什么是异常
运行程序时程序报错,称为程序出现异常
当执行程序时如果出现异常,出现异常的线程会直接崩溃,不再执行线程中后面的其它代码,整个线程直接结束
2. 异常捕获
1)语法一:可以捕获任何类型的异常
try:
代码块1
except:
代码块2
finally:
代码块3
其它语句
说明:
try
,except
:关键字,固定写法
代码块1
:和
try
保持一个缩进的一条或者多条语句
需要捕获异常的代码
代码块2
:和
except
保持一个缩进的一条或者多条语句
异常发生后会执行的代码
执行过程:
先执行代码块1,如果在执行代码块1时出现了异常,程序不会崩溃,直接执行代码块2,然后再执行其他语句
如果在执行代码块1时没有出现异常,代码块2不会执行,直接执行其他语句
while True:
try:
age = int(input('年龄:'))
print(age)
break
except:
print('输入错误, 重新输入')
2)语法二:捕获指定异常
try:
代码块1
except 异常类型:
代码块2
finally:
代码块3
其它语句
执行过程:
先执行代码块1,如果在执行代码块1时出现了异常,检查异常类型和except后的异常类型是否一致,
如果一致,程序不会崩溃,直接执行代码块2,然后再执行其他语句;如果不一致,程序直接崩溃.
如果在执行代码块1时没有出现异常,代码块2不会执行,直接执行其他语句
3)语法三:同时捕获指定的多个异常相同处理
try:
代码块1
except (异常类型1, 异常类型2, ...):
代码块2
finally:
代码块3
其它语句
4)语法四:同时捕获指定的多个异常不同处理
try:
代码块1
except 异常类型1:
代码块2
except 异常类型2:
代码块2
...
finally:
代码块3
其它语句
3. finally关键字
前面四种捕获异常的最后都可以添加finally关键字
finally后的代码段一定会在执行过try/except后执行,无论是否捕获了异常,无论是否崩溃
4. 抛出异常
主动让程序崩溃
语法:
raise 异常类型(异常类型必须是Exception的子类)
class AgeError(Exception):
def __str__(self):
return '年龄不在0-150之间'
age = 1000
if not 0 <= age <= 150:
raise AgeError
二、模块
1. 什么是模块
python中一个py文件就是一个模块
2. 如何在一个模块中使用另外一个模块的内容
如果要在一个模块中去使用另外一个模块中的内容,必须先导入模块
1)语法:
a.
import 模块名
导入指定模块,导入后可以在当前模块中使用被导入模块中所有的全局变量
以模块名.全局变量名的方式使用
b.
from 模块名 import 变量名1,变量名2...
导入指定模块,导入后只能使用import后面指定的变量
导入后,指定的全局变量在当前模块中直接使用,不需要加'模块名.'
c.
from 模块名 import *
导入指定模块,导入后可以在当前模块中使用被导入模块中所有的全局变量
导入后,全局变量在当前模块中直接使用,不需要加'模块名.'
d.
import 模块名 as 新模块名
导入后采用新模块名去使用被导入模块中的内容
e.
from 模块名 import 变量名1 as 新变量名1, 变量名2 as 新变量名2...
3. 导入模块的原理
当执行导入模块的代码时,会直接执行被导入模块中所有的代码
1)重复导入问题
import在导入模块时会自动检查该模块之前是否已经导入过,从而避免一个模块的重复导入
2)阻止模块中的内容被其它模块导入
将不希望被其它模块执行的语句写入if __name__ == '__main__':
对应的if语句中
四、包
1. 什么是包(package)
一个带有init.py文件的文件夹就是包
1)直接导入包,只执行init.py文件
import animal
print(animal.cat.c)
2)从包中导入指定的模块
from animal import brid, dog, cat
print(brid.b, dog.d, cat.c)
3)从包中的模块导入变量
from animal.cat import c
print(c)
五、hashlib模块简介
1. hash加密特点
a. 一致性,相同的数据采用同一个加密算法后的加密结果相同
b. 不可逆性,通过加密后的数据不能反向解析原数据
c. 采用相同的加密算法后的加密结果长度相同
2. 加密步骤
1) 根据加密算法创建hash对象
sha_256 = hashlib.sha256()
2)对数据进行加密
hash对象.update(加密数据):加密数据必须是二进制
字符串转二进制:
a. 字符串.encode()
b. bytes(字符串, encoding='utf-8')
sha_256.update(pw.encode())
# sha_256.update(bytes(pw, encoding='utf-8'))
3)根据hash对象获取密文(字符串类型)
result = sha_256.hexdigest()
print(result) # 8d969eef6ecad3c29a3a629280e686cf0c3f5d5a86aff3ca12020c923adc6c92