python基础---日志logging模块

logging模块使用

日志的作用

在一般情况下,日志作用相当于print的作用,用显示程序运行当中的一些信息,如当前迭代次数等,但是有时候我们会让程序在后台运行,此时print函数将失去作用,我们需要将程序运行的信息存放在文件中,最长见的是linux中nohup.out文件,事后我们可以从日志文件中查看程序运行的一些信息

logging模块的日志等级

从低到高为:
* DEBUG
* INFO
* WARNING
* ERROR
* CRITICAL
当程序指定一个日志等级后,程序会记录大于等于指定日志级别的日志信息

logging模块常用函数

longing.debug(msg, *args, **kwargs)   # 创建一个等级为DEBUG的日志记录
将上面的debug替换成info, warning, error, critical就是创建一条严重级别为info, warning, error, critical的日志记录
logging.basicConfig(**kwargs)    # 对日志记录器进行配置,如输出日志格式,日志等级等信息

logging的使用

1.只有级别大于等于日志记录器指定等级别的日志才会被输出

import logging
logging.debug("hello word, debug")
logging.info("hello word, info")
logging.error("hello word, error")
logging.warning("hello word, warning")
logging.critical("hello word, critical")

输出

ERROR:root:hello word, error
WARNING:root:hello word, warning
CRITICAL:root:hello word, critical
[Finished in 14.5s]

可以发现前两条日志没有被输出,这是因为默认日志记录器设置的日志级别为WARNING,因此只有大于等于WARNING级别的日志被输出

2.修改默认配置
使用basicConfig来修改默认配置,longging.basicConfig()接收参数如下:
filename指定写入日志的文件名
filemode指定日志文件打开模式,默认为“a”,就是追加模式
format指定日志输出包含的信息和顺序,下面会介绍自定义格式字段
datefmt指定日期时间格式

这里介绍几个经常用到的格式字符串字段
%(asctime)s日志发生的时间
%(levelname)s指定日志级别
%(message)s日志记录的内容

3.经过配置的日志输出
程序如下

import logging
LOG_FORMAT = "%(asctime)s  %(levelname)s  %(message)s"
logging.basicConfig(filename='./nohup.out', level=logging.DEBUG, format=LOG_FORMAT)

logging.debug("hello word, debug")
logging.info("hello word, info")
logging.error("hello word, error")
logging.warning("hello word, warning")
logging.critical("hello word, critical")

输出:此时因为指定了输出文件,控制台不会显示输出,日志信息记录在日志文件中,打开nohup.out文件其中内容如下

2020-01-10 21:32:03,006  DEBUG  hello word, debug
2020-01-10 21:32:03,006  INFO  hello word, info
2020-01-10 21:32:03,006  ERROR  hello word, error
2020-01-10 21:32:03,006  WARNING  hello word, warning
2020-01-10 21:32:03,006  CRITICAL  hello word, critical

因为设置了日志等级level=logging.DEBUG,因此会将大于等于DEBUG等级的日志都记录

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值