python中如何打印日志信息

这篇具有很好参考价值的文章主要介绍了python中如何打印日志信息。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

日志打印方式

常见的Python日志打印方式为使用内置函数print()或者logging模块打印日志。

  • print()只能将日志打印至控制台,不推荐此方式
  • logging模块默认将日志打印至控制台,也可以配置打印到指定日志文件,推荐使用此方式
logging模块
日志等级

logging提供了函数来做日志处理,分别为debug()/info()/warning()/error()/critical(),对应日志的五个等级DEBUG/INFO/WARNING/ERROR/CRITICAL。如下表所示。

函数 日志等级 等级值 说明
debug() DEBUG 10 调试模式下的日志,一般是给程序员看的
info() INFO 20 程序正常运行时输出的日志
warning() WARNING 30 警告信息,提示将来可能出现的问题
error() ERROR 40 程序运行过程中出现的错误信息
critical() CRITICAL 50 严重错误,表明软件已罢工

设置日志等级后只会打印大于等于当前等级的日志,从logging模块的源码里可见日志等级大小排序如下。
python中如何打印日志信息
DEBUG等级值最小,因此会打印出所有等级的日志。
logging里的默认等级为WARNING,也就是说在不设置日志等级的情况下,只有WARNING/ERROR/CRITICAL的日志才会被打印输出。

打印输出
  1. 如果只是打印至控制台,使用basicConfig()函数即可。默认的日志收集器名称为root,可以在创建日志对象时设置该名称。
logging.basicConfig(level=logging.INFO)
  1. 如果需要打印至日志文件,可参考如下示例代码。
# 创建日志对象(不设置时默认名称为root)
log = logging.getLogger('test_http')
# 设置日志级别(默认为WARNING)
log.setLevel('INFO')
# 设置输出渠道(以文件方式输出需设置文件路径)
file_handler = logging.FileHandler('test.log', encoding='utf-8')
file_handler.setLevel('INFO')
# 设置输出格式(实例化渠道)
fmt_str = '%(asctime)s %(thread)d %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s'
formatter = logging.Formatter(fmt_str)
# 绑定渠道的输出格式
file_handler.setFormatter(formatter)
# 绑定渠道到日志收集器
log.addHandler(file_handler)

def test_login():
    log.info("login start...")

if __name__ == '__main__':
    log.setLevel(logging.ERROR)
    test_login()

输出至log文件的日志格式如下:
python中如何打印日志信息文章来源地址https://www.toymoban.com/news/detail-461584.html

到了这里,关于python中如何打印日志信息的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • python中打印日志

    一、日志介绍 1、日志级别:日志的优先级、重要性或者严重程度 2、日志的作用:调试程序,跟踪定位bug,分析用户行为与数据统计 3、常见的日志级别(从小级别到大级别排序):         debug:调试级别,打印非常详细的日志信息,通常用于代码调试         inf

    2024年02月09日
    浏览(27)
  • solidity学习-如何在智能合约中打印Log日志

    在写合约的过程中经常会遇到一些错误。这个时候想要查看合约运行过程中的一些数据,那么就可以用以下方法: 在合约中创建一个Event,起名为Log 在想要打印日志的地方调用事件 emit Log(...),就可以查看运行过程中的数据了 如下图: 点击deploy,在控制台就可以查看打印出

    2024年02月11日
    浏览(13)
  • MyBatis实战:如何将拼接的SQL打印到日志

    哈喽,大家好,我是木头左! 在日常开发中,经常会遇到拼接SQL的情况,这时候,如何将拼接的SQL打印到日志,以便追踪和调试呢?本文将详细介绍MyBatis如何实现这一功能。 MyBatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis避免了几乎所有的

    2024年04月11日
    浏览(19)
  • springboot 下mybatis-plus 如何打印sql日志和参数到日志文件

    网上很多说法打印sql日志的方法在application.properties配置文件中 但是上述配置只能将sql日志打印到控制台,无法打印到日志文件中 参考下面这个文档,将sql日志打印到日志文件中 https://www.ius7.com/a/305 1:设置mybatisplus包下的日志级别为DEBUG; 2:设置项目mapper目录的日志级别为DE

    2024年02月14日
    浏览(17)
  • 软件测试Pytest实现接口自动化应该如何在用例执行后打印日志到日志目录生成日志文件?

    Pytest可以使用内置的logging模块来实现接口自动化测试用例执行后打印日志到日志目录以生成日志文件。以下是实现步骤: 1、在pytest配置文件(conftest.py)中,定义一个日志输出路径,并设置logging模块。 2、在测试用例中调用logging模块,输入需要生成的日志信息。 3、运行p

    2024年02月10日
    浏览(25)
  • Java 面试题之 Logback 打印日志是如何获取当前方法名称的?

    在 Java 中,有四种方法可以获取当前正在执行方法体的方法名称,分别是: 使用 Thread.currentThread().getStackTrace() 方法 使用异常对象的 getStackTrace() 方法 使用匿名内部类的 getClass().getEnclosingMethod() 方法 Java 9 的 Stack-Walking API 本文将根据以上四种方法来给大家进行具体讲解,不过

    2024年02月05日
    浏览(17)
  • Python中打印彩色信息的方法

    在Python中,可以使用print()函数打印出彩色信息。在使用print()打印之前,需要调用os标准库对系统进行设置。 os是Operating System的简写,即“操作系统”。os标准库是一个操作系统接口模块,提供了使用操作系统相关功能的函数。 需要通过import导入该库,代码如下所示: 可以通

    2024年02月07日
    浏览(10)
  • Mybatis-Plus详解(新建maven项目、查询所有信息、打印SQL日志、实现CRUD(增删改查)、分页、条件查询且分页,前后端分离式开发)

    MyBatis-Plus(opens new window) (简称MP) 是一个MyBatis(opens new window)的增强工具,在MyBatis的基础上只做增强不做改变,为简化开发、提高效率而生。想查看官网相关内容的化我这里提供了官网地址:https://baomidou.com/ 无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般

    2024年02月04日
    浏览(22)
  • 【ARM 嵌入式 编译 Makefile 系列 2 - Makefile 如何打印信息】

    请阅读 【ARM GCC Makefile 编译专栏导读】 下篇文章:【ARM 嵌入式 编译 Makefile 系列 2.1 - Makefile info,warn, error 打印详细介绍】 上篇文章:【ARM 嵌入式 编译 Makefile 系列 1 - Makefile 如何调用 shell 脚本】 在Makefile中,我们可以使用echo命令来打印信息。这种方法适用于大多数的 UNI

    2024年02月12日
    浏览(13)
  • nginx如何设置access.log打印请求头、请求体等信息

    通常我们使用nginx的默认配置,access.log日志中打印的信息会很少。如果我们想查询某次请求的请求头和请求体去排查问题会十分麻烦。但是nginx其实自带了很多可配置的参数。下面我们来介绍一下,并给大家一个常用的配置示例。 在http结构内,server结构外添加以下配置: 在

    2024年02月11日
    浏览(23)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包