最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

python实现log日志的示例代码

来源:动视网 责编:小OO 时间:2020-11-27 14:21:51
文档

python实现log日志的示例代码

使用logger.addHandler(handler)添加多个规则,# 就可以让一个logger记录多个日志,# coding=utf-8import loggingimport osimport timeLEVELS={';debug';:logging.DEBUG.';info';:logging.INFO.';warning';:logging.WARNING.';error';:logging.ERROR.';critical';:logging.CRITICAL,mode=';w';,对于记录的每个日志,他需要有一套规则,比如记录的格式(formatter),# 等级(level)等等。
推荐度:
导读使用logger.addHandler(handler)添加多个规则,# 就可以让一个logger记录多个日志,# coding=utf-8import loggingimport osimport timeLEVELS={';debug';:logging.DEBUG.';info';:logging.INFO.';warning';:logging.WARNING.';error';:logging.ERROR.';critical';:logging.CRITICAL,mode=';w';,对于记录的每个日志,他需要有一套规则,比如记录的格式(formatter),# 等级(level)等等。


下面为大家分享一篇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")

文档

python实现log日志的示例代码

使用logger.addHandler(handler)添加多个规则,# 就可以让一个logger记录多个日志,# coding=utf-8import loggingimport osimport timeLEVELS={';debug';:logging.DEBUG.';info';:logging.INFO.';warning';:logging.WARNING.';error';:logging.ERROR.';critical';:logging.CRITICAL,mode=';w';,对于记录的每个日志,他需要有一套规则,比如记录的格式(formatter),# 等级(level)等等。
推荐度:
标签: 日志 实现 代码
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top