python实现log日志的示例代码
2018-04-28 08:44
1256 查看
源代码:
# 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日志的示例代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- python实现apahce网站日志分析示例
- 代码实现获取log日志
- python脚本实现统计日志文件中的ip访问次数代码分享
- 能分析压缩的日志,且基于文件输入的PYTHON代码实现
- 代码实现获取log日志和logcat使用方法
- Python实现生成简单的Makefile文件代码示例
- python实现代码行数统计示例分享
- JNI开发第二篇通过反射实现C中调用java代码,并实现Log打印日志
- 快速实现基于Python的微信聊天机器人示例代码
- Python实现各种排序算法的代码示例总结
- 最右校招-服务器日志分析:一个十万行log统计问题的c语言代码的实现1
- commons.logging1.1.1源代码研究(3)-- 日志器Log接口,SimpleLog实现
- Python极简代码实现杨辉三角示例代码
- HMM原理介绍 示例 python代码实现
- python自动化工具日志查询分析脚本代码实现
- Python极简代码实现杨辉三角示例代码
- 代码实现获取log日志和logcat使用方法
- Python实现自动添加脚本头信息的示例代码
- 使用python分析git log日志示例
- Python实现socket信息发送和监听的简单代码示例