1.异常捕获
当程序发生异常的时候,默认情况会使程序崩溃,不能接着往后面继续执行;捕获异常就是让程序发生异常的时候不会崩溃,能够继续执行程序。一般在知道代码存在异常的时候,但又不能通过修改代码去避免,这个时候就可以通过异常捕获去处理异常。
2.捕获异常的语法
1)语法一:捕获所有的异常
try:
代码段1
except:
代码段2
finally:
代码段f
说明:try;except关键字,固定写法;代码段1需要捕获异常的一条语句或多条语句,代码段2出现异常后会执行的一条语句或者多条语句。finally:关键字,捕获异常的结构后面的最后都可以添加一个finally,finally后面的代码段一定会被执行。
执行过程:先执行代码段1,如果执行代码1的时候出现异常,程序不会崩溃会直接执行代码段2,如果没有出现异常,不会执行代码段2,但会执行finally后面的代码段。
2)语法二:捕获指定异常
try:
代码段1
except 异常类型:
代码段2
finally:
代码段3
说明:先执行代码1,如果执行代码块1的时候发生异常,检查出现的异常是否和except后面的异常类型相同,如果相同程序不奔溃,执行代码段2,否则程序直接崩溃,执行finally后面的代码段。
3)语法三:同时捕获多个异常
try:
代码段1
except (异常类型1,异常类型2,....):
代码段2
finally:
代码段3
4)语法四:同时捕获多个指定异常:
try:
代码段1
except 异常类型1:
代码段11
ecxept 异常类型2:
代码段22
finally:
代码段3
3.抛出异常:主动让程序奔溃
语法:raise 异常类型
说明:异常类型必须是Exceptionde子类
个人总结:程序在运行过程中会遇到异常,当我们知道异常类型的时候,可以直接把异常类型放在except语句后面,这样当捕获到一致的异常的时候,则保持运行程序不会崩溃,我们可以先使用raise 将异常抛出
class AgeError(Exception):
def __str__(self):
return '年龄值范围不在0~150'
age = 1000
if not 0 <= age <= 150:
raise AgeError
控制台显示raise 抛出的异常
Traceback (most recent call last):
File "C:/Users/hxj/Desktop/作业&代码/day13-异常和模块/03-异常.py", line 144, in
raise AgeError
__main__.AgeError: 年龄值范围不在0~150
class AgeError(Exception):
def __str__(self):
return '年龄值范围不在0~150'
age = 1000
if not 0 <= age <= 150:
raise FileNotFoundError
控制台显示raise抛出的异常:
Traceback (most recent call last):
File "C:/Users/hxj/Desktop/作业&代码/day13-异常和模块/03-异常.py", line 142, in
raise FileNotFoundError
FileNotFoundError
4.模块的使用
什么是模块:python中一个py文件就是一个模块。
怎么从一个模块中使用另一个模块中的内容:
要在一个模块中使用另一个模块,就必须先导入该模块,
1)语法:
a.import 模块名
导入指定模块后,可以在当前模块中使用导入模块的所有全局变量,使用方式“模块名.全局变量名”
import test
print(test.test_a, test.test_str1)
test.func1()
b.from 模块名 import 变量名1,变量名2,...
导入后,可以使用import后面的所有变量,导入的全局变量直接在模块中使用,使用时不用在前面添加“模块名”。
from test import test_a, func1
print(test_a)
c.from 模块名 import *
导入模块中的所有全局变量,使用时不需要添加"模块名"。
from test import *
print(test_a, test_str1)
func1()
d.import 模块名 as 新模块名
导入模块后,使用时“新模块名.变量名”
模块重命名:
import fileManager as FM
FM.write_file(900)
FM.json_read()
e.from 模块名 import 变量名1 as 新变量名1, 变量名2 as 新变量名2...
导入以后,使用时“新变量名”即可,不用加模块名
from test import a as ta
a = 100
print(a, ta)
2)导入模块的原理
当执行导入模块的代码的时候,会直接执行被导入的模块中的所有代码
1)重复导入的问题
import 在导入模块的时候会自动检测这个模块之前是否已经导入过,来避免一个模块重复导入
2)阻止模块中的内容被其他模块导入
将不需要被其他模块执行的语句写入“if name=='main':"对应的if语句中
1.包的使用
什么是包:一个带有init.py的文件就叫做包。
包就是在工程里面创建的一个Python Package,里面存有自己编辑的python file,当我们在其他py文件中使用到包中的函数的或者变量的时候,需要提前导入该包,导入的方式有以下几种:
1)直接导入包
直接导入包的时候,当前程序只执行被导入包的init.py文件里面的程序。
2)从包中导入指定的模块
语法:from 包名 import py1的文件名 py2的文件
py文件根据自己需要用的到导入进去
3)从包中的模块导入变量
语法:from 包名.py文件名 import 变量名
例如: from animal.cat import c
print(c)
加密(hashlib)
hashlib是python3.x提供的一个hash加密的模块;支持目前主流的一些加密运算:sha256、md5等。
1.加密特点
1)相等的数据采用同一个加密算法,保证加密的结果一样
2)通过加密的数据不能反向获取原数据
3)采用同样的加密算法,不管原来数据的大小是多少,加密后的数据长度是一样的
2.加密的步骤
1)根据加密的算法创建hash对象
hash = hashlib.md5()
2)对数据进行加密
hash.update(加密数据) -- 加密的数据必须是二进制数据
字符串转二进制:
a. 字符串.encode(encoding='utf-8')
b. bytes(字符串,encoding='utf-8')
例如:hash.update('你好!'.encode())
3)个悲剧hash对象获取加密后的数据(字符串类型)
result = hash.hexdigest()
print(result)
#完整的示例
import hashlib
pw = input('输入密码:')
hash = hashlib.md5()
hash.update(pw.encode())
result = hash.hexdigest()
print(result)