# # 项目经理
 # 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)

 # 抽象类和抽象方法 -> 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()
# 加密.  不可逆.
import hashlib

# md5对象
# obj = hashlib.md5(b"jflkasdjklfjaskljfdfjdsakljfklajsklfjaskljfklasjklasj") # 加盐
# obj.update("123456".encode("utf-8")) # 把要加密的内容给md5
# print(obj.hexdigest()) # 拿到密文 534b44a19bf18d20b71ecc4eb77c572f

# 我自己的MD5功能
def my_md5(s):
    obj = hashlib.md5(b"fkldsajlkfjlaksdjfkladsjfkladsjkldsjfklfjs")  # 加盐
    obj.update(s.encode("utf-8"))  # 把要加密的内容给md5
    return obj.hexdigest()

# print(my_md5("123456"))
# 应用
# 库里
# username = "wusir"
# password = "3e29aa0dc8a38b43c3479566cafc3cbe"
#
# # 登录
# uname = input("请输入你的用户名")
# upwd = input("请输入你的密码") # 123456
# if uname == username and my_md5(upwd) == password:
#     print("登录成功")
# else:
#     print("登录失败")

# 机器永远不会出错. 出错的只会是人
#
# print(1/0) # 报错. 程序会结束运行
# print("哈哈哈哈哈哈哈")
# 0不能作为除数 ,  在程序执行的时候产生了一个错误对象.
# 系统会抛出这个错误. 如果没有人处理错误. 错误就会被喷出给用户

# 处理异常: 在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("哈哈哈哈哈哈哈哈啊哈")

# 如何自己定义异常
# 随便写一个类. 这个类只要继承了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))
#
#
# class JackException(Exception):
#     pass

# 写一个男澡堂子
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:
    # ret = traceback.format_exc() # 查看堆栈信息, 看错误的
    # print(ret)
    print("出错了. 很可惜")

# 错误信息叫堆栈信息
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.warn("气死我了") # 30  警告
# logging.warning("还好吧")
# logging.info("提示") # 20 级
# logging.debug("开发的时候把这个开着") # 10
# 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("我才不去呢. 我们在北京. 离你那么远")

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()) # 把堆栈信息记录在日志文件中

python-类的约束,MD5,异常处理,日志的更多相关文章

  1. 小学生绞尽脑汁也学不会的python(异常,约束,MD5加密,日志处理)

    小学生绞尽脑汁也学不会的python(异常,约束,MD5加密,日志处理) 异常处理(处理) 1.产生异常.raise 异常类(),抛出异常2. 处理异常: try: xxxxx # 尝试执行的代码. ...

  2. 异常处理,约束,MD5加密日志处理

    程序运行过程中产生的错误, 不正常 def chufa(a, b): try: # 尝试执行xxx代码 ret = a/b # 如果这里出现了错误. 异常. 系统内部会产生一个异常对象. 系统会把这个 ...

  3. Python——类与对象,异常处理

    类 class C1: def setdata(self,value): self.data = value def display(self): print(self.data) class C2( ...

  4. Python 类的约束

    # 项目经理 class Base: # 对子类进行了约束. 必须重写该方法 # 以后上班了. 拿到公司代码之后. 发现了notImplementedError 继承他 直接重写他 def login ...

  5. pyhon基础之约束和异常处理:

    约束和异常处理:内容梗概: 1. 类的约束 2. 异常处理 3. 自定义异常 4. 日志 1. 类的约束定义:约束是对类的约束常用方法:1. 提取父类.然后在父类中定义好方法.在这个方法中什么都不用干 ...

  6. python之路--类的约束, 异常处理, MD5, 日志处理

    一 . 类的约束 1. 写一个父类,父类中的某个方法要抛出一个异常 NotImplementedError class Base: # 对子类进行了约束. 必须重写该方法 # 以后上班了. 拿到公司代 ...

  7. python -- 约束、异常处理、MD5

    1.类的约束       1.写一个父类,父类中的某个方法要抛出一个异常 NotImplementedError class Base: # 对子类进行了约束,必须重写该方法 def login(se ...

  8. python--类的约束,异常处理,MD5加密,日志处理logging模块

    1.类的约束 在开发中,如果项目经理需要对类进行约束,可以有两种方式 1. 对子类进行约束 Base: #对子类进行约束,必须重写这个方法 # 在工作中发现了NotImplementedError之后 ...

  9. python学习笔记:第19天 类的约束、异常、MD5和logging

    目录 一.类的约束 二.异常处理: 三.MD5加密 四.日志(logging模块) 一.类的约束 真正写写项目的代码时都是多人协作的,所以有些地方需要约束程序的结构.也就是说,在分配任务之前就应该把功 ...

随机推荐

  1. 笔记:Linux(AWS Redhat)开机启动workman进程(/etc/rc.local必须是755权限)

    1.使用which命令查看php的安装路径 [root@ip---- ~]# which php /usr/bin/php 2.使用vim /etc/rc.local将要执行的命令加入/etc/rc. ...

  2. python-浅拷贝和深拷贝

    浅拷贝和深拷贝 浅拷贝 拷贝的副本共享内部对象的引用的拷贝为浅拷贝 举个栗子 list1 = [1, 2, [3, 4], (5, 6)] list2= list(list1) print(" ...

  3. Qt 快捷键 复制当前行 向上复制 && 向下复制

    网上的答案不一,我的快捷键是默认的配置,未做过修改. 向前复制当前行: Ctrl + Alt + up (向上箭头) 向后复制当前行:Ctrl + Alt + down(向下箭头) 补充一个:Ctrl ...

  4. 检查文件是否被修改或者被破坏工具 md5

    检查文件和对应的md5值是否一致.

  5. Bukkit之yaml动态读取

    在使用bukkit框架写插件的时候会经常使用到yml格式的文件来存储配置或者玩家数据,这里来说一下实现yml中数据的动态读写: 先来看一下yml文件中的内容结构 public boolean addB ...

  6. 今天整理了一下Winform用的UI插件信息

    平时主要用了一下几个比较好的UI控件: 1:IrisSkin2 皮肤插件.这是一款与编程开发相关的素材资源,主要是提供一些采用IrisSkin2.dll控件进行软件窗口换肤的素材文件,包括一些GIF图 ...

  7. Python- 解决PIP下载安装速度慢

    让PIP源使用国内镜像,提升下载速度和安装成功率. 国外的源下载速度太慢,而且经常出现下载后安装出错问题.把PIP安装源替换成国内镜像,可以大幅提升下载速度,还可以提高安装成功率. 国内源: 新版ub ...

  8. DRF之认证组件源码解析

    认证组件  认证的几种方法:cookie,session,token几种.但是session会使服务器的压力增大,所以我们经常使用的是token.获取唯一的随机字符串: 登陆携带token值的处理: ...

  9. fpga板制作调试过程记录

    2010-09-11 22:49:00 昨天淘宝准备买块fpga核心板学习,为了练习焊接,我让老板给我散料及pcb板自己焊接. 一,在物料到之前的准备: 我先设计了一下焊接测试计划 1,检查电路板:特 ...

  10. Windows cmd 一些命令

    运行是Windows的必要组成部分,可以简单理解为一个应用程序快速调用的组件.通过“运行”窗口,可以调用Windows中任何应用程序甚至DOS命令.一般可以搜索百度百科 微软件(窗口) + R    ...