python實現(xiàn)log日志的示例代碼
更新時間:2018年04月28日 08:44:47 作者:shengnan_only
下面小編就為大家分享一篇python實現(xiàn)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):
#創(chuàng)建并打開一個新文件
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
#靜態(tài)方法
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可以看做是一個記錄日志的人,對于記錄的每個日志,他需要有一套規(guī)則,比如記錄的格式(formatter),
# 等級(level)等等,這個規(guī)則就是handler。使用logger.addHandler(handler)添加多個規(guī)則,
# 就可以讓一個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實現(xiàn)log日志的示例代碼就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
解決python3 整數(shù)數(shù)組轉bytes的效率問題
這篇文章主要介紹了解決python3 整數(shù)數(shù)組轉bytes的效率問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-03-03
Python高級編程之消息隊列(Queue)與進程池(Pool)實例詳解
這篇文章主要介紹了Python高級編程之消息隊列(Queue)與進程池(Pool),結合實例形式詳細分析了Python消息隊列與進程池的相關原理、使用技巧與操作注意事項,需要的朋友可以參考下2019-11-11

