day13总结(2019-08-07)

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)

你可能感兴趣的:(day13总结(2019-08-07))