python内置日志模块logining

'''
软件开发通过日志纪录程序的运行是一种良好的开发习惯,python标准库自带日志模块,在程序模块中直接调用标准库
的日志模块,通过日志开发者可以清楚的了解到发生了哪些事情,包括出现了哪些错误。
在logging中日志文件分为5个等级
日志等级(level)            描述
DEBUG                       调试信息,通常在诊断问题时使用
INFO                        普通信息,确认程序按预期进行
WARNING                     警告信息,表示发生意想不到的信息,程序会继续运行
ERROR                       错误信息,程序运行出现问题,程序某些功能不能执行
CRITICAL                    危险信息,一个严重的错误,导致程序无法继续运行
'''
'''
import logging #导入日志模块
logging.basicConfig(filename="test.log",level=logging.DEBUG) #创建日志文件,设置等级
#-----运行文件写入三个信息分别为debug、info、warning三种级别
logging.debug("debug")
logging.info("info")
logging.warning("warning")
'''
#-----创建一个日志文件管理器------------------------------------------
'''
第一步:初始化日志处理器对象
第二步:设置级别
第三步:定义handler(控制显示)
第四步:格式化输出
'''
import logging
logger = logging.getLogger() #实例化一个日志处理器对象

logger.setLevel(logging.DEBUG) #设置级别

sh = logging.StreamHandler() #设置在控制台输出
sh.setLevel(logging.DEBUG) #达到级别就输出
fh = logging.FileHandler("test.log",encoding="utf-8") #写入到文件中
fh.setLevel(logging.DEBUG)#达到级别就输出

#定义输出格式
formatter = logging.Formatter(
    "时间:%(asctime)s,"
    "日志级别:%(levelname)s,"
    "日志内容:%(message)s"
)

sh.setFormatter(formatter) #设置在控制台输出的格式
fh.setFormatter(formatter) #设置写入文件的格式

logger.addHandler(sh) #使handler生效
logger.addHandler(fh)

#在日志管理器中写入5个文件级别分别为:debug、info、warning、error、critical
if __name__ == '__main__':
    logger.debug("调试中")
    logger.info("正在运行")
    logger.warning("警告")
    logger.error("错误")
    logger.critical("崩溃")
#----在函数调试中使用日志管理器------------------------
def func(n):
    try:
        num = 20/n
        logger.info(num)
    except Exception as s:
        logger.error(s)
func("sss")

 

posted @ 2019-05-10 23:13  上古战神  阅读(306)  评论(0编辑  收藏  举报