1. 简介
追踪某些软件运行时所发生事件的方法, 可以在代码中调用日志中某些方法来记录发生的事情
一个事件可以用一个可包含可选变量数据的消息来描述
事件有自己的重要性等级
2. 使用logging日志系统四大组件
使用代码如下
import os, time, logging, sys from common.plugs.get_config import r_config base_dir = os.path.dirname(os.path.dirname(os.path.dirname(__file__))) if sys.platform == "win32": env_conf_dir = os.path.join(base_dir, 'common/conf/env_config.ini').replace('/', '\\') else: env_conf_dir = os.path.join(base_dir, 'common/conf/env_config.ini') log_path = r_config(env_conf_dir, "log", "log_path") class log: def __init__(self, log_path): self.logname = os.path.join(log_path, '{0}.log'.format(time.strftime('%y-%m-%d'))) def console_log(self, level, message): # 创建一个logger logger = logging.getlogger() logger.setlevel(logging.debug) # 创建一个handler,用于 debug 写入日志文件 debug_file = logging.filehandler(self.logname, 'a+', encoding='utf-8') debug_file.setlevel(logging.debug) # 再创建一个handler,用于输出到控制台 ch = logging.streamhandler() ch.setlevel(logging.debug) # 定义handler的输出格式 formatter = logging.formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s') debug_file.setformatter(formatter) ch.setformatter(formatter) # 给logger添加handler logger.addhandler(debug_file) logger.addhandler(ch) # 记录一条日志 if level == 'info': logger.info(message) elif level == 'debug': logger.debug(message) elif level == 'warning': logger.warning(message) elif level == 'error': logger.error(message) elif level == 'critical': logger.critical(message) logger.removehandler(ch) logger.removehandler(debug_file) debug_file.close() def debug(self, message): #最详细日志信息, 多用于问题诊断 self.console_log('debug', message) def info(self, message): #仅次于debug, 多用于记录关键点信息, 确保程序按预期执行 self.console_log('info', message) def warning(self, message): #低等级故障, 但程序仍能运行, 如磁盘空间不足警告 self.console_log('warning', message) def error(self, message): #由于比warning严重的问题, 导致某些功能不能正常运行时的记录 self.console_log('error', message) def critical(self, message): 严重错误, 导致应用程序不能继续运行时的记录 self.console_log('critical', message) if __name__ == '__main__': log(log_path).info("adasd") log(log_path).error("dsadasddasd") '''
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。
如对本文有疑问, 点击进行留言回复!!
网友评论