zoukankan      html  css  js  c++  java
  • day 20 约束 异常处理 MD5

    1.类的约束(重点):
    写一个父类.  父类中的某个方法要抛出一个异常  NotImplementError
    # 项目经理
    class Base:
        # 对子类进行了约束. 必须重写该方法
        # 以后上班了. 拿到公司代码之后. 发现了notImplementedError 继承他 直接重写他
        def login(self):
            #     没有被实现错误
            raise NotImplementedError("你要重写一下login这个方法. 否则报错!") # 抛异常  .
     
    class Member(Base):
        def login(self):
            print("我是普通人登录")
     
    class BaWu(Base):
        def login(self):
            print("吧务登录")
     
    class Houtai(Base):
        def login(self): # 报错, 上层程序员写代码没有按照规范来
            print("后台登录")
     
    # 整合这些个功能
    def deng(obj):
        obj.login()
     
    m = Member()
    bw = BaWu()
    ht = Houtai()
     
    deng(m)
    deng(bw)
    deng(ht)
    抽象类和抽象方法:
    from abc import ABCMeta, abstractmethod
    class Base(metaclass = ABCMeta):
          @abstractmenthod
          def fangfa(self):
                pass
    # 抽象类和抽象方法 -> java c#
    # 抽象方法不需要给出具体的方法体. 抽象方法内只写一个pass就可以了
    # 在一个类中如果有一个方法是抽象方法. 那么这个类一定是一个抽象类
    # 抽象类中. 如果有抽象方法. 此时这个类不能创建对象
    # 如果一个类中所有的方法都是抽象方法. 这个类可以被称为接口类
     
    # 写一个抽象方法:导入一个模块
    from abc import ABCMeta, abstractmethod
     
    # 此时抽象类不能创建对象
    class Animal(metaclass=ABCMeta): # 写完这东西. 就是个抽象类
        @abstractmethod # 抽象方法
        def chi(self): pass # 吃应该只是一个抽象概念. 没办法完美的描述出来吃什么东西
     
        # 抽象类中可以有正常的方法
        def dong(self):
            print("动物会动")
     
    # class Cat(Animal): # 此时猫里面也有一个抽象方法, 此时的猫是创建不了对象的
    #     pass
     
    class Cat(Animal):
        def chi(self): # 重写父类中的抽象方法
            print("猫喜欢吃鱼")
     
    a = Cat()
    a.chi()
    a.dong()
    2.异常处理.  try cxcept   raise(重点)
    try:
        代码
    except  异常类:
          除了错,如何处理异常
    except  异常类:
          除了错,如何处理异常
    except  异常类:
          除了错,如何处理异常
    else:
        当程序不出错
    finally:
         不管出不出错,都要执行
    处理异常: 在python中可以通过try.....except... 来处理错误
    try:
        print(1 / 0)
    except Exception:
        print("出错了, 出现了ZeroDivisionError")
     
    print("哈哈哈哈哈哈哈") # 可以正常运行.
    所有的异常的根是Exception, 所有的异常类都会默认继承Exception
    try:
        print(1/10)
        # f = open("哈哈哈哈哈", mode="r")
        # d = {[]:123}
    except ZeroDivisionError: # 可以处理所有错误
        print("除以0出错了")
    except FileNotFoundError:
        print("文件不存在的错误")
    except Exception: # 兜底的
        print("其他错误")
    else: # 当try中的代码不产生任何错误的时候. 会自动的执行else里的代码
        pass
    finally: # 最终. 不管出错还是不出错. 都要执行最后的finally 一般用来收尾
        print("哈哈哈哈哈哈哈哈啊哈")
    如何手动抛出异常和如何自己定义异常
    raise  异常类('信息')
    class 类(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))
     
     
    class JackException(Exception):   如何自己定义异常
        pass
    import  traceback
    traceback.format_exc()
      ###用来查看堆栈信息(错误信息叫堆栈信息)
    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:
        # ret = traceback.format_exc() # 查看堆栈信息, 看错误的
        # print(ret)
        print("出错了. 很可惜")
    3.MD5 加密    
    import hashlib     
    obj = hashlib.md5(b'盐')
    obj.update(b'要加密的内容')
    print(obj.hexdigest())
    md5对象
    obj = hashlib.md5(b"jflkasdjklfjaskljfdfjdsakljfklajsklfjaskljfklasjklasj") # 加盐
    obj.update("123456".encode("utf-8")) # 把要加密的内容给md5
    print(obj.hexdigest()) # 拿到密文534b44a19bf18d20b71ecc4eb77c572f
    应用
    username = "wusir"
    password = "3e29aa0dc8a38b43c3479566cafc3cbe"
     
    # 登录
    uname = input("请输入你的用户名")
    upwd = input("请输入你的密码") # 123456
    if uname == username and my_md5(upwd) == password:
        print("登录成功")
    else:
        print("登录失败")
    4.日志处理(不要记,留一份,侧重点在用)
    等级:
          critical: 50
          error :40
          warning: 30
          info :  20
          debug : 10
    具体格式:
    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=10) # 当前配置表示 10以上的分数会被写入日件
     
    # 向日志文件写入内容
    logging.critical("今天嫂子没有来") # 50, 几乎是最高的
    logging.error("昨天嫂子来了") # 40 平时使用最多的就是他
    logging.warn("气死我了") # 30  警告
    logging.warning("还好吧")
    logging.info("提示") # 20 级
    logging.debug("开发的时候把这个开着") # 10
    logging.log(999, "宝宝今天有懵逼了")
    创建一个依赖操作日志的对象logger(依赖FileHandler)
    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("我才不去呢. 我们在北京. 离你那么远")
    举例应用:
    import traceback
     
    class GenderException(Exception):
        pass
     
     
    class Person:
        def __init__(self, name, gender):
            self.name = name
            self.gender = gender
            logger1.info(f"这个人的名字是{self.name}, 这个人的性别是:{self.gender}")
     
        def xizao(self):
            print(f"{self.name}在洗澡")
     
    class ZaoTang:
     
        def nan(self, ren):
            if ren.gender == "男":
                ren.xizao()
            else:
                raise GenderException("我这里要的是男人")
     
        def nv(self, ren):
            if ren.gender == "女":
                ren.xizao()
            else:
                raise GenderException("我这里要的是女人")
     
     
    try:
        p1 = Person("赵亚磊", "男")
        p2 = Person("林志玲", "女")
        zaotang = ZaoTang()
        zaotang.nan(p2)
        zaotang.nv(p1)
    except GenderException:
        print("走错屋里了")
        logger1.error("走错屋了.. ")
        logger1.error(traceback.format_exc()) # 把堆栈信息记录在日志文件中
     
  • 相关阅读:
    WCF系列(一)BasicHttpBinding 和 WsHttpBinding 的不同点
    SQL Server中的事务与锁
    领域驱动设计之领域模型
    http请求到响应经历的阶段
    vs调试
    c# 基本值类型及其默认值
    ASP.NET中JSONP的两种实现以及其他跨域解决方案的简单实现
    通俗易懂,什么是.NET?什么是.NET Framework?什么是.NET Core?
    最完整的数据倾斜解决方案(spark)
    Spark性能调优
  • 原文地址:https://www.cnblogs.com/yanghongtao/p/10169877.html
Copyright © 2011-2022 走看看