文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

python中打印日志

2023-09-25 17:52

关注

一、日志介绍
1、日志级别:日志的优先级、重要性或者严重程度
2、日志的作用:调试程序,跟踪定位bug,分析用户行为与数据统计
3、常见的日志级别(从小级别到大级别排序):
        debug:调试级别,打印非常详细的日志信息,通常用于代码调试
        info:信息级别,打印一般的日志信息,突出强调程序的运行过程
        warming:警告级别,打印警告信息,表明可能出现潜在的错误
        error:错误级别,打印错误异常信息,该级别的错误可能导致程序无法运行
        critical:严重错误级别,这表明系统可能无法继续运行
4、当指定日志级别后,程序会记录所有日志级别大于或者等于指定级别的东西
5、日志的格式:
        %(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 打印日志的信息

二、logging用法

基本用法:

# 导库,一个标准的第三方库用于日志的打印import logging# 基本用法logging.debug('这是一条调试信息')logging.info('这是日志信息')logging.warning('打印警告')logging.error('这是一条错误信息')logging.critical('这是一条严重错误信息')

输出信息如下:

WARNING:root:打印警告ERROR:root:这是一条错误信息CRITICAL:root:这是一条严重错误信息

上述代码中我们打印了五种日志,但是输出结果只有三种,这是因为指定日志级别后,程序会记录大于或者等于指定级别的日志,下面我们来指定打印debug级别的日志:

# 导包import logging# 设置日志级别 打印日志logging.basicConfig(level=logging.DEBUG)# 基本用法logging.debug('这是一条调试信息')logging.info('这是日志信息')logging.warning('打印警告')logging.error('这是一条错误信息')logging.critical('这是一条严重错误信息')

输出结果如下:

DEBUG:root:这是一条调试信息INFO:root:这是日志信息WARNING:root:打印警告ERROR:root:这是一条错误信息CRITICAL:root:这是一条严重错误信息

我们还可以指定日志的格式,演示输出时的日志格式化:

import loggingfm = "%(asctime)s %(levelname)s [%(name)s] [%(filename)s] [%(funcName)s:%(lineno)d]"# 设置日志级别 打印日志logging.basicConfig(level=logging.DEBUG,format=fm)# 基本用法logging.debug('这是一条调试信息')logging.info('这是日志信息')logging.warning('打印警告')logging.error('这是一条错误信息')logging.critical('这是一条严重错误信息')

 输出信息如下:

2023-07-17 22:48:59,062 DEBUG [root] [logger.py] [:36]2023-07-17 22:48:59,063 INFO [root] [logger.py] [:37]2023-07-17 22:48:59,063 WARNING [root] [logger.py] [:38]2023-07-17 22:48:59,063 ERROR [root] [logger.py] [:39]2023-07-17 22:48:59,063 CRITICAL [root] [logger.py] [:40]

我们还可以输出日志到指定的文件:

# 导库,一个标准的第三方库用于日志的打印import loggingfm = "%(asctime)s %(levelname)s [%(name)s] [%(filename)s] [%(funcName)s:%(lineno)d]"# 设置日志级别 打印日志 设置日志打印的文件路径logging.basicConfig(level=logging.DEBUG,format=fm,filename="testlog//log01.log")# 基本用法logging.debug('这是一条调试信息')logging.info('这是日志信息')logging.warning('打印警告')logging.error('这是一条错误信息')logging.critical('这是一条严重错误信息')

指定了日志打印的文件后点击运行,打开testlog文件夹下的log01文件,能发现已经打印了:

来源地址:https://blog.csdn.net/m0_51619381/article/details/131776540

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯