day13总结

异常

运行程序的时候程序报错,又叫程序出现异常;
当执行程序的时候如果出现异常,出现异常的线程会直接崩溃(多线程不会),不会在执行程序中后面的其他代码

异常捕获

###1.语法1:
try:
    代码块1
except:
    代码块2

try,except都是关键字,固定写法。

代码块1:和try保持一个缩进的一条或多条语句,需要捕获异常的代码
代码块2:和except保持一个缩进的一条或多条语句,发生异常后会输出的异常语句。

执行过程:先执行代码块1,如果在执行代码块1的时候出现了异常,程序不崩溃,直接执行代码块2,然后再执行后面的其他语句,如果语句1没异常就不执行代码2,而是直接执行后面的其他语句。

2.语法2:捕获指定异常

try:
    代码块1
except 异常类型:
    代码块2

执行过程:先执行代码块1,如果执行代码块1的时候出现异常,检查异常类型和except后面的异常,如果一致程序不崩溃,然后执行代码块2,如果不一致,程序直接崩溃;如果在执行代码块1的时候没有出现异常,就直接跳过代码块2,执行后面的语句。

3.语法3:捕获多个指定的多个异常

try:
    代码块1
except (异常类型1,异常类型2 ,,,):
    代码块2

4.语法4:同时捕获指定多个异常

try:
    代码块1
except 异常类型1:
    代码块2
except 异常类型2:
    代码块3
……

5.finally关键字

前面4种异常捕获的结构后面都可以加上finally,无论任何情况finally后面的代码块都会运行。

try:
    代码块1
except:
    代码块2
finally:
    代码块3

其他语句
……

6.抛出异常

主动让程序崩溃(只要执行raise语句程序就会崩溃并报错异常类型)

语法:
raise 异常类型

说明:异常类型必须是Exception的子类

自己写异常:
class AgeError(Exception):
    def __str__(self):
        return '年龄不在0-150'

age = -100
if not 0 <= age <=150:
    raise AgeError

模块

1.什么是模块?

python中一个py文件就是一个模块

2.怎么在一个模块中使用另一个模块中的内容

如果要在一个模块中使用另一个模块中的内容,必须先导入模块

1)语法:

import 模块名 --- 导入指定模块,导入后可以在当前模块中使用模块中的所有的全局变量,
以‘模块名.全局变量名’的方式去使用

from 模块名 import 变量名1,变量名2,… -- 导入指定模块,导入模块后只能使用import后面指定的变量,导入后指定的全局变量在当前模块中直接使用,不用在前面加‘模块名.’

from 模块名 import * -- 导入指定模块,导入后可以在当前模块中使用模块中的所有的全局变量,
导入后指定的全局变量在当前模块中直接使用,不用在前面加‘模块名.’

import 模块名 as 新模块名 -- 导入后采用新模块名去使用模块中的变量

from 模块名 import 变量名1 as 新变量名1,变量名2 as 新变量名2,… -- 给变模块中的变量重命名

注意:导入模块的本质就是进入到模块中把模块中所有的代码全部执行一遍

3.倒入模块的原理

1)重复导入问题

import 在导入模块的时候会自动检测这个模块之前是否被导入过,来避免一个模块的重复导入(可避免死循环)-- 这种重复导入在python中不会报错,在其它语言会报错

2)阻止模块中的内容被其他模块导入

将不需要被其他模块执行的语句放在
"if _ name _ == '_ main _'"下面。

4.包

1)什么是包?

本质就是一个文件夹(对模块(py文件)进行封装),是一个带有“init.py”文件的文件夹

2)从包中导入模块:

from 包名 import 模块名 -- 导入包中的模块

3)from 包.模块 import 变量名

5.模块time

时间戳:来统计两段时间的时间差
print(time.time())

6.hashlib(加密模块)

由Python3.x提供的一个hash加密的模块:支持目前主流的一些加密算法:sha256,md5等

hash加密的特点:

a.相等的数据采用同一个加密算法,保证加密结果一样
b.通过加密后的数据不能反向获取原数据
c.采用同样的加密算法,不管原数据的大小是多少,加密后的数据的长度是一样的

7.加密的步骤

pw = int(input('请输入密码'))

1)根据加密的算法创建hash对象

hash = hashlib.sha256()

2)对数据进行加密

hash对象.update(加密数据) -- 加密数据必须是二进制数据
字符串转二进制方法:a. 字符串.encode('utf-8') b. bytes(字符串,encoding='utf-8')
hash.update(pw.encode())

3)根据hash对象获取加密后的数据

result = hash.hexdigest()
print(result )----------字符串类型

import hashlib
pwd = input('please input password:')
hash_dx = hashlib.md5()
hash_dx.update('你好!'.encode())
hash_dx.update(pwd.encode())
res = hash_dx.hexdigest()
print(res)

你可能感兴趣的:(day13总结)