python log日志_python实现log日志的示例代码

# coding=utf-8

import logging

import os

import time

LEVELS={'debug':logging.DEBUG,\

'info':logging.INFO,\

'warning':logging.WARNING,\

'error':logging.ERROR,\

'critical':logging.CRITICAL,}

logger=logging.getLogger()

level='default'

def createFile(filename):

path=filename[0:filename.rfind('/')]

if not os.path.isdir(path):

os.makedirs(path)

if not os.path.isfile(filename):

#创建并打开一个新文件

fd = open(filename,mode='w',encoding='utf-8')

fd.close()

class MyLog:

log_filename='E:/quality/it/pyrequest-master/log/itest.log'

err_filename='E:/quality/it/pyrequest-master/log/err.log'

dateformat='%Y-%m-%d %H:%M:%S'

logger.setLevel(LEVELS.get(level,logging.NOTSET))

createFile(log_filename)

createFile(err_filename)

#注意文件内容写入时编码格式指定

handler=logging.FileHandler(log_filename,encoding='utf-8')

errhandler=logging.FileHandler(err_filename,encoding='utf-8')

@staticmethod

#静态方法

def debug(log_message):

setHandler('debug')

logger.debug("[DEBUG "+getCurrentTime()+"]"+log_message)

removerhandler('debug')

@staticmethod

def info(log_message):

setHandler('info')

logger.info("[INFO "+getCurrentTime()+"]"+log_message)

removerhandler('info')

@staticmethod

def warning(log_message):

setHandler('warning')

logger.warning("[WARNING "+getCurrentTime()+"]"+log_message)

removerhandler('warning')

@staticmethod

def error(log_message):

setHandler('error')

logger.error("[ERROR "+getCurrentTime()+"]"+log_message)

removerhandler('error')

@staticmethod

def critical(log_message):

setHandler('critical')

logger.critical("[CRITICAL "+getCurrentTime()+"]"+log_message)

removerhandler('critical')

# logger可以看做是一个记录日志的人,对于记录的每个日志,他需要有一套规则,比如记录的格式(formatter),

# 等级(level)等等,这个规则就是handler。使用logger.addHandler(handler)添加多个规则,

# 就可以让一个logger记录多个日志。

def setHandler(level):

if level=='error':

logger.addHandler(MyLog.errhandler)

#handler=logging.FileHandler(log_filename)

#把logger添加上handler

logger.addHandler(MyLog.handler)

def removerhandler(level):

if level=='error':

logger.removeHandler(MyLog.errhandler)

logger.removeHandler(MyLog.handler)

def getCurrentTime():

return time.strftime(MyLog.dateformat,time.localtime(time.time()))

if __name__=="__main__":

MyLog.debug("This is debug message")

MyLog.info("This is info message")

MyLog.warning("This is warning message")

MyLog.error("This is error message")

MyLog.critical("This is critical message")

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值