python 面向对象(五)约束 异常处理 MD5 日志处理
###############################总结######################
1.异常处理
raise:抛出异常
try:
可能出现错误代码
execpt 异常类 as e:
异常处理
execpt 异常类 as e:
异常处理
else:
如果上面的代码没有报错,执行这里
finally:
收尾
自定义异常: 随便写个类. 继承Exception
try:
print(1/0)
f=open('hahah',mode='r')
except ZeroDivisionError:
print("除余0 出错了")
except FileNotFoundError:
print('文件不存在的错误')
except Exception:#我是兜低的
print('其他错误')
else: #当try中的代码互惠产生任何错误的时候执行
pass
finally:#不管出错还是不出错 都执行
print('收尾工作') #############自定义异常###########
# 如何自己定义异常
# 随便写一个类. 这个类只要继承了Exception 这个类就是一个异常类就可以作为raise对象
class CulException(Exception):
pass
# 如何手动抛出异常
def cul(a, b):
# 只能是数字相加
if (type(a) == int or type(a) == float ) and (type(b) == int or type(b) == float):
return a + b
else:
# 抛出异常
# raise 异常类(错误信息)
raise CulException("我没办法给你处理这样的运算") print(cul("就不放, 气死你",2)) ##################结果
Traceback (most recent call last):
File "D:/python_work_s18/day20约束 异常 日志处理/test.py", line 58, in <module>
print(cul('气死你',2))
File "D:/python_work_s18/day20约束 异常 日志处理/test.py", line 57, in cul
raise CulException('我处理不鸟这个类型')
__main__.CulException: 我处理不鸟这个类型
import traceback#用来查看堆栈信息 class GenderException(Exception):
pass
class Person:
def __init__(self,name,gender):
self.name=name
self.gender=gender
def xizao(self):
print(f'{self.name}在洗澡')
def nan_zao_tang_zi(ren):
if ren.gender=='男':
ren.xizao()
else:
raise GenderException('性别不对,去对面看看')
try:
p1=Person('张三','男')
p2=Person('李四','女')
nan_zao_tang_zi(p1)
nan_zao_tang_zi(p2)
except GenderException:
print('出错了,很可惜') #这时候的错误没有堆信息 需要用下面的堆
# ret=traceback.format_exc()
# print(ret)
2. 约束
父类和子类.
在父类中声明方法. 要求子类必须重写它
1. 抛出异常. raise NotImplementError
2. 抽象类和抽象方法
from abc import ABCMeta, abstractmethod
在父类声明的时候, metaclass= ABCMeta
方法上面加@abstractmethod
子类必须重写这个抽象方法.
class Base:
def login(self):
raise NotImplementedError('你要重写这个方法')
class PuTong(Base):
def login(self):
print('我是普通功能模块')
class BaWu(Base):
def login(self):
print('我是帖子管理模块')
class HouTai(Base):
def denglu(self):
print('我是后台管理模块')
#整合这些功能
def deng(obj):
obj.login()
m=PuTong()
bw=BaWu()
ht=HouTai() deng(m)
deng(bw)
deng(ht) ######结果 就会抛出异常
Traceback (most recent call last):
File "D:/python_work_s18/day20约束 异常 日志处理/test.py", line 44, in <module>
deng(ht)
File "D:/python_work_s18/day20约束 异常 日志处理/test.py", line 37, in deng
obj.login()
File "D:/python_work_s18/day20约束 异常 日志处理/test.py", line 25, in login
raise NotImplementedError('你要重写这个方法')
NotImplementedError: 你要重写这个方法
我是普通功能模块
我是帖子管理模块
# 写一个抽象方法:导入一个模块
from abc import ABCMeta,abstractmethod class Animal(metaclass=ABCMeta):#写完这个东西就是个抽象类
@abstractmethod#抽象方法
def chi(self):pass #吃应该只是一个抽象概念 没法完全的描述出吃什么东西
#抽象类中可以有正常的方法
def dong(self):
print('动物会动')
class Cat(Animal):
pass
# def chi(self):
# print('猫喜欢吃鱼')
a=Cat()
a.chi()
a.dong() #######结果 后面的继承 要覆盖父类的方法
a=Cat()
TypeError: Can't instantiate abstract class Cat with abstract methods chi
3. M5D
1. 引入模块
import hashlib
2. 创建md5对象(实例化)
obj = hashlib.md5(b"盐")
3. 把加密的内容交给md5
obj.update(bytes)
4. 获取密文
obj.hexdigest()
import hashlib
obj=hashlib.md5(b'')#加盐
obj.update(''.encode('utf-8'))
print(obj.hexdigest())#拿到密文
import hashlib
def MyMd5(k):
obj=hashlib.md5(b'121212')
obj.update(k.encode('utf-8'))
return obj.hexdigest()
print(MyMd5('2222'))
4. 日志
logging模块
basicConfig
filename
format
datefmt
level 级别
CRITICAL 50
ERROR 40
WARNING 30
INFO 20
DEBUG 10
NOTEST 0
import logging
# 配置好日志的处理, 默认就是GBK
logging.basicConfig(filename='x1.txt', # 把日志信息写入的文件名
format='%(asctime)s - %(name)s - %(levelname)s -%(module)s: %(message)s',
datefmt='%Y-%m-%d %H:%M:%S', # 时间的格式
level=40) # 当前配置表示 10以上的分数会被写入日件
# 向日志文件写入内容
logging.critical("今天嫂子没有来") # 50, 几乎是最高的
logging.error("昨天嫂子来了") # 40 平时使用最多的就是他
logging.warning("还好吧")# 30 警告
logging.info("提示") # 20 级
logging.debug("开发的时候把这个开着") #
logging.log(999, "宝宝今天有懵逼了")
方法二
import logging
# 创建一个操作日志的对象logger(依赖FileHandler)
file_handler = logging.FileHandler('l1.log', 'a', encoding='utf-8') # 创建文件
file_handler.setFormatter(logging.Formatter(
fmt="%(asctime)s - %(name)s - %(levelname)s -%(module)s: %(message)s")) # 设置日志文件的格式
logger1 = logging.Logger('腾讯qq', level=10) # 创建一个日志文件处理对象
logger1.addHandler(file_handler) # 把文件添加到日志 logger1.error("麻花藤明天请大家吃饭. 去不去?") # 再创建⼀个操作⽇志的对象logger(依赖FileHandler)
file_handler2 = logging.FileHandler('l2.log', 'a', encoding='utf-8')
file_handler2.setFormatter(logging.Formatter(
fmt="%(asctime)s - %(name)s -%(levelname)s -%(module)s: %(message)s"))
logger2 = logging.Logger('百度贴吧', level=logging.DEBUG)
logger2.addHandler(file_handler2) logger2.error("我才不去呢. 我们在北京. 离你那么远")
python 面向对象(五)约束 异常处理 MD5 日志处理的更多相关文章
- 巨蟒python全栈开发-第20天 核能来袭-约束 异常处理 MD5 日志处理
一.今日主要内容 1.类的约束(对下面人的代码进行限制;项目经理的必备技能,要想走的长远) (1)写一个父类,父类中的某个方法要抛出一个异常 NotImplementedError(重点) (2)抽象 ...
- python之路--类的约束, 异常处理, MD5, 日志处理
一 . 类的约束 1. 写一个父类,父类中的某个方法要抛出一个异常 NotImplementedError class Base: # 对子类进行了约束. 必须重写该方法 # 以后上班了. 拿到公司代 ...
- python --- 20 约束 异常处理 MD5 日志
一.类的约束 1.抛出异常 NotImplementedError 2.抽象方法 含有抽象方法的类是抽象类 抽象类中的方法全是抽象方法的是接口 抽象类不能创建对象 二.异常处理 处理完后代码可继 ...
- python 约束. 异常处理. MD5. 日志处理
一.约束 1.抛异常 # # 项目经理写的 class Base: # # 对子类进行了约束. 必须重写该方法 # # 以后上班了. 拿到公司代码之后. 发现了NotImplementedError ...
- 20 约束 异常处理 MD5 日志
三十九, 一.类的约束 1.抛出异常 NotImplementedError 2.抽象方法 含有抽象方法的类是抽象类 抽象类中的方法全是抽象方法的是接口 抽象类不能创建对象 二.异常处理 处理完 ...
- python--类的约束, 异常处理, MD5, 日志处理
一 . 类的约束 1. 写一个父类,父类中的某个方法要抛出一个异常 NotImplementedError class Base: # 对子类进行了约束. 必须重写该方法 # 以后上班了. 拿到公司代 ...
- Python面向对象(约束,异常处理,md5加密)(五)
1. 类的约束 1. 写一个父类. 父类中的某个方法要抛出一个异常 NotImplementedError class Base: def login(self): raise NotImplemen ...
- python--类的约束,异常处理,MD5加密,日志处理logging模块
1.类的约束 在开发中,如果项目经理需要对类进行约束,可以有两种方式 1. 对子类进行约束 Base: #对子类进行约束,必须重写这个方法 # 在工作中发现了NotImplementedError之后 ...
- python约束 异常 MD5 日志处理
一.约束 1.用父类执行约束 子类继承父类,用重写方法,对子类的方法进行约束. class Foo: def login(self): # 对子类进行约束,该方法需要重写 # 没有执行的错误 rais ...
随机推荐
- BZOJ3676[Apio2014]回文串——回文自动机
题目描述 考虑一个只包含小写拉丁字母的字符串s.我们定义s的一个子串t的“出 现值”为t在s中的出现次数乘以t的长度.请你求出s的所有回文子串中的最 大出现值. 输入 输入只有一行,为一个只包含小写字 ...
- monkey测试的脚本
monkey测试脚本编写思路: 配置文件: 1.测试安装包路径 2.执行monkey脚本的次数 3.执行monkey的点击数 4.包名 读取配置文件: 1.配置文件有一个section 2.读取配置文 ...
- Hard Life UVA - 1389(最大密度子图 输出点集)
题意: rt 解析: 我用的第二种方法... s向所有的边连权值为1的边 所有的点向t连权值为mid的边 如果存在u - > v 则边向u和v分别连一条权值为INF的边 二分mid 用dfs ...
- 自学华为IoT物联网之路
自学华为IoT物联网之路 01 自学华为IoT物联网_01 物联网概述 02 自学华为IoT物联网_02 常见物联网通信技术 03 自学华为IoT物联网_03 公共事业物联网常见问题及解决方案 04 ...
- 【BZOJ5211】[ZJOI2018]线图(树哈希,动态规划)
[BZOJ5211][ZJOI2018]线图(树哈希,动态规划) 题面 BZOJ 洛谷 题解 吉老师的题目是真的神仙啊. 去年去现场这题似乎骗了\(20\)分就滚粗了? 首先\(k=2\)直接算\(k ...
- css基本语法及页面引用
css基本语法 css的定义方法是: 选择器 { 属性:值; 属性:值; 属性:值;} 选择器是将样式和页面元素关联起来的名称,属性是希望设置的样式属性每个属性有一个或多个值.代码示例: div{ w ...
- NOIP2013华容道(BFS+乱搞)
n<=30 * m<=30 的地图上,0表示墙壁,1表示可以放箱子的空地.q<=500次询问,每次问:当空地上唯一没有放箱子的空格子在(ex,ey)时,把位于(sx,sy)的箱子移动 ...
- centos7系统排错
系统排错 troubleshooting winPE --光盘或u盘启动盘 产生一个PE系统(类似内存上跑的临时系统) 系统排错 rescue 模式 (挽救模式) 类似windows winPE模式 ...
- 洛谷P2805 植物大战僵尸
题意:给你一张图,每个节点保护若干节点. 当一个节点不被保护的时候,你就可以gay掉它. gay每个节点都有收益(可能为负),求最大总收益. 解:首先发现是一个最大权闭合子图. 把保护关系变成被保护, ...
- 洛谷P3975 弦论
题意:求一个串的字典序第k小的子串/本质不同第k小的子串. 解:一开始我的想法是在后缀树上找,但是不知道后缀树上的边对应的是哪些字符... 然而可以不用fail树转移,用转移边转移即可. 先建一个后缀 ...