码迷,mamicode.com
首页 > 其他好文 > 详细

约束、自定义异常、加密、日志处理

时间:2018-08-31 21:28:47      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:bst   debug   print   知识   object   message   encoding   and   user   

一、约束

  BaseMessage类用于约束,约束其派生类:保证派生类中必须编写方法,不然执行就可能报错。

class BaseMessage(object):
    def send(self,x1):
        """
        必须继承BaseMessage,然后其中必须编写send方法。用于完成具体业务逻辑。
        """
        raise NotImplementedError(".send() 必须被重写.")

class Email(BaseMessage):
    def send(self,x1):
        """
        必须继承BaseMessage,然后其中必须编写send方法。用于完成具体业务逻辑。
        """
        pass

obj = Email()
obj.send(1)

  1.什么是接口以及作用:

    接口是一种数据类型,主要用于约束派生类中必须实现的指定方法

    python中不存在接口,java、C#中存在

  2.python中使用什么来约束:

    抽象类+抽象方法(编写上麻烦,不推荐使用)

from abc import ABCMeta,abstractmethod

class Base(metaclass=ABCMeta): # 抽象类

    def f1(self):
        print(123)

    @abstractmethod
    def f2(self):   # 抽象方法
        pass

class Foo(Base):

    def f2(self):
        print(666)

obj = Foo()
obj.f1()

    人为主动抛出异常

  3.约束时,抛出的异常是否可以使用其他:

不专业:raise Exception(".send() 必须被重写.")
专业:raise NotImplementedError(".send() 必须被重写.")

二、自定义异常

class MyException(Exception):    #必须继承Exception
    def __init__(self, code, msg):
        self.code = code
        self.msg = msg

try:
    # 知识点:主动抛出异常 
    raise MyException(1000, 操作异常)

except KeyError as obj:
    print(obj, 1111)
except MyException as obj:  # 知识点:捕获异常 
    print(obj, 2222)
except Exception as obj:
    print(obj, 3333)

三、加密(hashlib模块)

  关键字:撞库、加盐

技术分享图片
import hashlib

SALT = b2erer3asdfwerxdf34sdfsdfs90

def md5(pwd):
    # 实例化对象
    obj = hashlib.md5(SALT)
    # 写入要加密的字节
    obj.update(pwd.encode(utf-8))
    # 获取密文
    return obj.hexdigest() # 21232f297a57a5a743894a0e4a801fc3 # 66fbdc0f98f68d69cd458b0cee975fe3 # c5395258d82599e5f1bec3be1e4dea4a


user = input("请输入用户名:")
pwd = input("请输入密码:")
if user == oldboy and md5(pwd) == c5395258d82599e5f1bec3be1e4dea4a:
    print(登录成功)
else:
    print(登录失败)
View Code

四、日志

  日志主要是给开发人员看的,用于排查错误

技术分享图片
import logging
logger = logging.basicConfig(filename="zhangqing",
                             format="%(asctime)s - %(name)s - %(levelname)s -%(module)s:  %(message)s",
                             datefmt="%Y-%m-%d %H:%M:%S",
                             level=30)

logging.debug(x1) # 10
logging.info(x2)  # 20
logging.warning(x3) # 30
logging.error(x4)    # 40
logging.critical(x5) # 50
logging.log(10,x6)

import traceback

def func():
    try:
        a = a +1
    except Exception as e:
        # 获取当前错误的堆栈信息
        msg = traceback.format_exc()
        logging.error(msg)
func()
View Code

  自定义日志

技术分享图片
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(s1, level=logging.ERROR)
logger1.addHandler(file_handler)


logger1.error(123123123)



# 在创建一个操作日志的对象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(s2, level=logging.ERROR)
logger2.addHandler(file_handler2)

logger2.error(666)
View Code

 

约束、自定义异常、加密、日志处理

标签:bst   debug   print   知识   object   message   encoding   and   user   

原文地址:https://www.cnblogs.com/qq849784670/p/9567526.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!