异常
1.什么是异常
运行程序的时候程序报错,又叫程序出现异常
当执行程序的时候,如果出现异常,出现异常的线程会直接崩溃,不再执行线程中后面其他的代码
2.异常捕获
-
1)语法一:
try - except能够捕获任何异常
try:
代码块1
except:
代码块2-
说明:
try/except - 关键字,固定写法
代码块1 - 和try保持一个缩进的一条或者多条语句
(需要捕获异常的代码块)
代码块2 - 和except保持一个缩进的一条或者多条语句
(异常发生后会执行的代码) -
执行过程:
先执行代码块1,如果在执行代码块1的时候出现了异常,程序不崩溃,直接执行代码块2,然后再执行其它语句;如果在执行代码块1的时候没有出现异常,代码块2不会执行,直接执行其它语句
-
try:
age = int('a')
except:
print('出现异常,年龄只能是数字')
print('最后')
-
2)语法二:
try - except 异常类型: 捕获指定异常
try:
代码块1
except 异常类型:
代码块2- 执行过程:
先执行代码块1,如果在执行代码块1的时候出现了异常,检查异常类型和except后面的异常类型是否一致,
如果一致程序不崩溃,直接执行代码块2,然后再执行其它语句
如果不一致,程序直接崩溃
如果在执行代码块1的时候没有出现异常,代码块2不会执行,直接执行其它语句
- 执行过程:
try:
# print('a'+23)
age = int('a')
except ValueError:
print('出现异常,年龄只能是数字')
print('最后')
-
3)语法三:
try - except (异常类型1,异常类型2,...): 同时捕获指定的多种异常
try:
代码块1
except (异常类型1,异常类型2,...):
代码块2 -
4)语法四:
try - except (异常类型1,异常类型2,...): 同时捕获指定的多种异常
try:
代码块1
except 异常类型1:
代码块11
except 异常类型2:
代码块22
3.finally关键字
前面四种捕获异常结构的最后面都可以添加一个finally
- 例:
try:
代码块1
except:
代码块2
finally:
代码块3
其它语句
- finally中代码块一定会执行,和其它语句的区别就在于如果上面程序崩溃,其它语句不会执行,但是finally中的语句会执行
4.抛出异常
主动让程序崩溃
-
语法:
raise 异常类型: -
说明:
以指定异常类型崩溃,异常类型必须是exception的子类
模块
1.什么是模块
python中一个py文件就是一个模块
2.怎么在一个模块中使用另外一个模块中的内容
如果要在一个模块中使用另外一个模块中的内容,必须先导入模块
1)语法:
-
import 模块名(就是py文件的名字) - 导入指定模块,导入后可以在当前模块中使用模块中所有的全局变量, 以'模块名.全局变量名'的方式去使用
-
form 模块名 import 变量名1,变量名2,... - 导入指定模块,导入后只能使用import后面指定的变量,导入后指定的全局变量在当前模块中直接使用,不用在前面加'模块名.'
-
form 模块名 import * - 导入指定模块,导入后指定模块中所有的全局变量都可以使用,不用在前面加'模块名.'
重命名:
import 模块名 as 新模块名 - 导入后采用新模块名去使用模块中的内容
from 模块名 import 变量名1,变量名2, as 新变量名2
3.载入模块的原理
当执行导入模块的代码的时候,会直接执行被导入的模块中所有的代码
1)重复导入
import在导入模块的时候会自动检查当前模块是否已经导入,如果已经导入,不会再导;所以重复导入不会有问题,因为根本不会导
2)阻止模块中的内容被其它模块导入
将不需要被其它模块执行的语句写入if name == 'main':对应的if语句中
if name == 'main':
外部导入不会执行的部分,但是不影响自身的使用
包
1.什么是包
一个带有init.py文件的文件夹就叫包,
1)直接导入包
import 包名 - 实际上是执行了包中的init,所以在init中要用form import导入包中其它模块
2)从包中导入指定的模块
from 包名 import 模块名1,模块名2,...
3)从包中指定模块导入指定变量
form 包名.模块名 import 变量
hashlib
1.什么是hashlib
- hashlib是python3.x提供的一个hash加密的模块:支持目前主流一些加密算法:sha256、md5等
hash加密特点:
a.相等的数据采用同一个加密算法,保证加密结果一样
b.通过加密后的数据不能反向获取原数据
c.采用同样的加密算法,不管原数据的大小是多少,加密后的数据的长度是一样的
2.加密步骤
1)根据加密算法创建hash对象
hash=hashlib.sha256()
2)对数据进行加密
- hash对象.update(加密数据) - 加密数据必须是二进制数据
- 字符串转二进制: a.字符串.encode)(encoding='utf-8') b. bytes(字符串,encoding='utf-8')
pw=input('请输入密码:')
hash.update('你好!'.encode()) # 二级加密,还可以多添加几个多层加密
hash.update(pw.encode())
3)根据hash对象获取加密后的数据(字符串类型)
result = hash.hexdigest()
print(result)
网友评论