时间:2021-05-22
源代码:
# coding=utf-8import loggingimport osimport timeLEVELS={'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日志的示例代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Python实现从log日志中提取ip的方法。分享给大家供大家参考,具体如下:log日志内容如下(myjob.log):124.90.53.68-
本文实例为大家分享了python+logging+yaml实现日志分割的具体代码,供大家参考,具体内容如下1、建立log.yaml文件version:1disa
操作系统:CentOS6.9_x64go语言版本:1.8.3问题描述golang的log模块提供的有写日志功能,示例代码如下:/*golanglogexampl
1.我要读取log日志的”执行成功”的个数,log日志编码格式为GBK2.显示报错,大致意思是说utf-8的代码不能解析log日志3.后来想想把log日志用GB
Linux下nginx生成日志自动切割的实现方法1、编辑切割日志的shell程序,目录自定#vi/data/nginx/cut_nginx_log.sh输入代码