python的logging模块
python提供了一个日志处理的模块,那就是logging。
导入logging模块使用以下命令:
import logging
logging模块的用法:
1.简单的将日志打印到屏幕上
import logging logging.debug("This is debug message") logging.info("This is info message") logging.warning("This is warning message") logging.error("This is error message") logging.critical("This is critical message")
会在屏幕上显示出以下内容:
WARNING:root:This is warning message
ERROR:root:This is error message
CRITICAL:root:This is critical message
默认情况下python的logging模块将日志打印到了标准输出中,也就是屏幕上,且只显示了大于等于WARNING级别的日志.
这说明默认的日志级别设置为WARNING(日志级别等级CRITICAL > ERROR > WARNING > INFO > DEBUG)
默认直接输出的日志格式为日志级别:Logger名称:用户:输出消息。
2.现在修改日志的默认输出级别为debug,重新设定输出时间的格式,
import logging logging.basicConfig(level=logging.DEBUG, format="%(asctime)s %(levelname)s %(message)s", datefmt="%Y-%m-%d %H:%M:%S") logging.debug("This is debug message") logging.info("This is info message") logging.warning("This is warning message") logging.error("This is error message") logging.critical("This is critical message")
会在屏幕上显示以下信息;
2017-07-02 10:41:18 DEBUG This is debug message
2017-07-02 10:41:18 INFO This is info message
2017-07-02 10:41:18 WARNING This is warning message
2017-07-02 10:41:18 ERROR This is error message
2017-07-02 10:41:18 CRITICAL This is critical message
3.现在想把程序产生的日志写入文件当中,可以这样设定:
import logging logging.basicConfig(level=logging.DEBUG, format="%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s", datefmt="%Y-%m-%d %H:%M:%S", filename="log.txt", filemode="w") logging.debug("This is debug message") logging.info("This is info message") logging.warning("This is warning message") logging.error("This is error message") logging.critical("This is critical message")
运行程序,会在脚本目录下生成一个名为log.txt的文件。
log.txt文件的内容如下:
2017-07-02 10:49:13 logging_modules.py[line:211] DEBUG This is debug message
2017-07-02 10:49:13 logging_modules.py[line:212] INFO This is info message
2017-07-02 10:49:13 logging_modules.py[line:213] WARNING This is warning message
2017-07-02 10:49:13 logging_modules.py[line:214] ERROR This is error message
2017-07-02 10:49:13 logging_modules.py[line:215] CRITICAL This is critical message
在这里设定日志文件的输出使用的是basicConfig这个方法:
logging.basicConfig函数各参数: filename: 指定输出日志的文件名 filemode: 和file函数意义相同,指定日志文件的打开模式,写入模式用'w',追加模式使用'a' format: 指定输出的内容的格式,其中可以使用的参数有: %(levelno)s: 指定输出日志的级别的数值 %(levelname)s: 指定输出日志的级别的名称 %(pathname)s: 指定当前执行程序的路径,其实就是sys.argv[0] %(filename)s: 指定保存日志文件的名字 %(funcName)s: 打印日志的当前函数 %(lineno)d: 打印日志的当前行号 %(asctime)s: 打印日志的时间 %(thread)d: 打印线程ID %(threadName)s: 打印线程名称 %(process)d: 打印进程ID %(message)s: 打印日志信息 datefmt: 指定时间格式,同time.strftime() level: 设置日志级别,默认为logging.WARNING,这里设定为logging.DEBUG
4.既想现在就看到输出的日志,又想把程序运行的日志保存在文件里,方便以后查看,可以这样设定:
import logging logger=logging.getLogger() #创建一个file_handle变量,用于把日志写入到文件 file_handle=logging.FileHandler("log1.txt") #创建一个stream_handle变量,用于输出日志到屏幕上 stream_handle=logging.StreamHandler() #设定输出日志的级别为debug级别 logger.setLevel(logging.DEBUG) #设定输出日志的格式 fmt=logging.Formatter("%(asctime)s-%(levelname)s-%(message)s") #为写入文件的日志添加已设定的格式 file_handle.setFormatter(fmt) #为输出到屏幕的日志添加已设定的格式 stream_handle.setFormatter(fmt) logger.addHandler(file_handle) logger.addHandler(stream_handle) #设定输出日志的信息 logging.debug("This is debug message") logging.info("This is info message") logging.warning("This is warning message") logging.error("This is error message") logging.critical("This is critical message")
运行程序后,会生成一个名为log1.txt的文件,文件的内容和屏幕上显示的内容都是:
2017-07-02 11:04:53,622-DEBUG-This is debug message
2017-07-02 11:04:53,623-INFO-This is info message
2017-07-02 11:04:53,623-WARNING-This is warning message
2017-07-02 11:04:53,623-ERROR-This is error message
2017-07-02 11:04:53,624-CRITICAL-This is critical message
在这里,还可以添加以下选项用来指定把要写入文件的日志设定为debug级别,而输出到屏幕上的日志还是warning级别
fh.setLevel(logging.Debug)
内容扩展:
日志的作用
通过log的分析,可以方便用户了解系统或软件、应用的运行情况;如果你的应用log足够丰富,也可以分析以往用户的操作行为、类型喜好、地域分布或其他更多信息;如果一个应用的log同时也分了多个级别,那么可以很轻易地分析得到该应用的健康状况,及时发现问题并快速定位、解决问题,补救损失。
简单来讲就是,我们通过记录和分析日志可以了解一个系统或软件程序运行情况是否正常,也可以在应用程序出现故障时快速定位问题。比如,做运维的同学,在接收到报警或各种问题反馈后,进行问题排查时通常都会先去看各种日志,大部分问题都可以在日志中找到答案。再比如,做开发的同学,可以通过IDE控制台上输出的各种日志进行程序调试。对于运维老司机或者有经验的开发人员,可以快速的通过日志定位到问题的根源。可见,日志的重要性不可小觑。日志的作用可以简单总结为以下3点:
程序调试
了解软件程序运行情况,是否正常
软件程序运行故障分析与问题定位
如果应用的日志信息足够详细和丰富,还可以用来做用户行为分析,如:分析用户的操作行为、类型洗好、地域分布以及其它更多的信息,由此可以实现改进业务、提高商业利益。
到此这篇关于Python中关于logging模块的学习笔记的文章就介绍到这了,更多相关Python之logging模块相关介绍内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!
本文向大家介绍Node.js中的模块机制学习笔记,包括了Node.js中的模块机制学习笔记的使用技巧和注意事项,需要的朋友参考一下 Javascript自诞生以来,曾经没有人拿它当做一门编程语言。在Web 1.0时代,这种脚本语言主要被用来做表单验证和网页特效。直到Web 2.0时代,前端工程师利用它大大提升了网页上的用户体验,JS才被广泛重视起来。在JS逐渐流行的过程中,它大致经历了工具类库、组
本文向大家介绍python模块smtplib学习,包括了python模块smtplib学习的使用技巧和注意事项,需要的朋友参考一下 python的smtplib提供了一种很方便的途径发送电子邮件。它对smtp协议进行了简单的封装。 smtp协议的基本命令包括: HELO 向服务器标识用户身份 MAIL 初始化邮件传输 mail from: RCPT 标识单个的邮件接收人;常
本文向大家介绍NodeJS学习笔记之MongoDB模块,包括了NodeJS学习笔记之MongoDB模块的使用技巧和注意事项,需要的朋友参考一下 一,开篇分析 这篇属于扩展知识篇,因为在下面的文章中会用到数据库操作,所以今天就来说说它(Mongodb模块)。 (1),简介 MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。 Mo
本文向大家介绍Python学习笔记之os模块使用总结,包括了Python学习笔记之os模块使用总结的使用技巧和注意事项,需要的朋友参考一下
本文向大家介绍Python中的类学习笔记,包括了Python中的类学习笔记的使用技巧和注意事项,需要的朋友参考一下 Python使用中面向对象的语言,支持继承、多态; 定义一个Person类: 可以修改Person的类方法 Person().sayHello也是一个函数,可以赋值给变量,并可以直接调用; Person.sayHello与Person().sayhello并不是同一个对象,直
本文向大家介绍详解node child_process模块学习笔记,包括了详解node child_process模块学习笔记的使用技巧和注意事项,需要的朋友参考一下 NodeJs是一个单进程的语言,不能像Java那样可以创建多线程来并发执行。当然在大部分情况下,NodeJs是不需要并发执行的,因为它是事件驱动性永不阻塞。但单进程也有个问题就是不能充分利用CPU的多核机制,根据前人的经验,可以通过