百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

每天一个 Python 库:logging 用法精讲,高效简洁的输出日志

off999 2025-05-28 19:40 75 浏览 0 评论

一、为什么你必须掌握 logging?


你是否还在用 print() 调试程序?

简单场景 OK,但当项目逐渐复杂,print 就显得力不从心:


  • 无法区分信息等级
  • 不带时间,无法定位日志时间点
  • 不易写入日志文件
  • 无法控制是否显示


logging 是 Python 标准库,轻量、强大且灵活,帮你统一管理日志信息,先看疗效。



二、logging 五大等级速查表

学习本来就不是一蹴而就的事,不过只要你肯练、敢用,坚持一阵子,你一定能看到变化!


#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :Fish 
@File    :D11.py
@Date    :2025/4/23 19:27 
@Author : malijie
"""
import logging

logging.debug("调试信息")
logging.info("正常信息")
logging.warning("警告信息")
logging.error("错误信息")
logging.critical("严重错误")

等级

说明

适用场景

DEBUG

调试级别

开发阶段

INFO

普通信息

程序正常运行时记录

WARNING

警告

潜在问题

ERROR

错误

出现异常

CRITICAL

严重错误

程序无法运行


为什么只输出了3行?

这是因为 Python 的 logging 模块有一个默认的日志等级:WARNING

低于这个等级的日志(如 DEBUG 和 INFO)默认不会被输出。

#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :Fish 
@File    :D11.py
@Date    :2025/4/23 19:27 
@Author : malijie
"""
import logging

logging.basicConfig(level=logging.DEBUG)

logging.debug("调试信息")
logging.info("正常信息")
logging.warning("警告信息")
logging.error("错误信息")
logging.critical("严重错误")

再看效果如何



三、日志同时写入控制台和文件(推荐)

#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :Fish 
@File    :D11.py
@Date    :2025/4/23 19:27 
@Author : malijie
"""
import logging
import colorlog
import os
from datetime import datetime

# 创建日志器
logger = logging.getLogger("my_logger")
logger.setLevel(logging.DEBUG)

# 控制台处理器(彩色)
console_handler = colorlog.StreamHandler()
console_formatter = colorlog.ColoredFormatter(
    "%(log_color)s%(asctime)s - %(levelname)s - %(message)s",
    log_colors={
        'DEBUG': 'cyan',
        'INFO': 'green',
        'WARNING': 'yellow',
        'ERROR': 'red',
        'CRITICAL': 'bold_red',
    }
)
console_handler.setFormatter(console_formatter)

# 日志文件名(带时间)
log_dir = "logs"
os.makedirs(log_dir, exist_ok=True)
log_file = os.path.join(log_dir, f"log_{datetime.now().strftime('%Y%m%d_%H%M%S')}.log")

# 文件处理器(无颜色)
file_handler = logging.FileHandler(log_file, encoding='utf-8')
file_formatter = logging.Formatter("%(asctime)s - %(levelname)s - %(message)s")
file_handler.setFormatter(file_formatter)

# 添加两个处理器
logger.addHandler(console_handler)
logger.addHandler(file_handler)

# 输出不同等级日志
logger.debug("调试信息")
logger.info("正常信息")
logger.warning("警告信息")
logger.error("错误信息")
logger.critical("严重错误")

输出到 log_20250423_194518.log 文件:

2025-04-23 19:45:18,499 - DEBUG - 调试信息
2025-04-23 19:45:18,500 - INFO - 正常信息
2025-04-23 19:45:18,500 - WARNING - 警告信息
2025-04-23 19:45:18,500 - ERROR - 错误信息
2025-04-23 19:45:18,500 - CRITICAL - 严重错误



四、实用封装:获取通用 logger(建议写到工具模块)

#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :Fish 
@File    :D11.py
@Date    :2025/4/23 19:27 
@Author : malijie
"""
import logging
import os
from datetime import datetime
import colorlog


def get_logger(name="my_logger", log_dir="logs", level=logging.DEBUG):
    logger = logging.getLogger(name)
    logger.setLevel(level)

    # 避免重复添加处理器
    if logger.handlers:
        return logger

    # 控制台处理器(彩色)
    console_handler = colorlog.StreamHandler()
    console_formatter = colorlog.ColoredFormatter(
        "%(log_color)s%(asctime)s - %(levelname)s - %(message)s",
        log_colors={
            'DEBUG': 'cyan',
            'INFO': 'green',
            'WARNING': 'yellow',
            'ERROR': 'red',
            'CRITICAL': 'bold_red',
        }
    )
    console_handler.setFormatter(console_formatter)
    logger.addHandler(console_handler)

    # 文件处理器(不带颜色)
    os.makedirs(log_dir, exist_ok=True)
    log_file = os.path.join(log_dir, f"log_{datetime.now().strftime('%Y%m%d_%H%M%S')}.log")
    file_handler = logging.FileHandler(log_file, encoding="utf-8")
    file_formatter = logging.Formatter("%(asctime)s - %(levelname)s - %(message)s")
    file_handler.setFormatter(file_formatter)
    logger.addHandler(file_handler)

    return logger

调用方式:

#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :Fish 
@File    :test.py
@Date    :2025/4/23 20:01 
@Author : malijie
"""
import logging

from D11.D11 import get_logger

if __name__ == '__main__':
    logger = get_logger(level=logging.DEBUG)
    logger.debug("关税让美国进口订单开始腰斩")
    logger.info("特朗普就印控克什米尔发生恐袭发声")
    logger.warning("广州越秀一宾馆疑似发生火灾")
    logger.error("美在菲建全球最大战备仓库")
    logger.critical("特朗普再加关税!")



五、日志等级控制技巧


你可以通过 level 参数,灵活控制输出级别:

#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :Fish 
@File    :test.py
@Date    :2025/4/23 20:01 
@Author : malijie
"""
import logging

from D11.D11 import get_logger

if __name__ == '__main__':
    logger = get_logger(level=logging.WARNING)
    logger.debug("关税让美国进口订单开始腰斩")
    logger.info("特朗普就印控克什米尔发生恐袭发声")
    logger.warning("广州越秀一宾馆疑似发生火灾")
    logger.error("美在菲建全球最大战备仓库")
    logger.critical("特朗普再加关税!")

上面这行设置只输出 WARNING 及以上等级的日志。



六、logging 在自动化测试中的典型应用

日志通常用于记录:

  • 接口请求 / 响应数据
  • 步骤执行结果
  • 错误堆栈信息
  • 断言失败信息
log.info(f"请求接口成功,返回状态码:{status_code}")
log.error(f"断言失败,返回数据:{response.json()}")

结合 try-except 提升稳定性:

#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :Fish 
@File    :D11.py
@Date    :2025/4/23 19:27 
@Author : malijie
"""
import logging
import os
from datetime import datetime
import colorlog


def get_logger(name="my_logger", log_dir="logs", level=logging.DEBUG):
    logger = logging.getLogger(name)
    logger.setLevel(level)

    # 避免重复添加处理器
    if logger.handlers:
        return logger

    # 控制台处理器(彩色)
    console_handler = colorlog.StreamHandler()
    console_formatter = colorlog.ColoredFormatter(
        "%(log_color)s%(asctime)s - %(levelname)s - %(message)s",
        log_colors={
            'DEBUG': 'cyan',
            'INFO': 'green',
            'WARNING': 'yellow',
            'ERROR': 'red',
            'CRITICAL': 'bold_red',
        }
    )
    console_handler.setFormatter(console_formatter)
    logger.addHandler(console_handler)

    # 文件处理器(不带颜色)
    os.makedirs(log_dir, exist_ok=True)
    log_file = os.path.join(log_dir, f"log_{datetime.now().strftime('%Y%m%d_%H%M%S')}.log")
    file_handler = logging.FileHandler(log_file, encoding="utf-8")
    file_formatter = logging.Formatter("%(asctime)s - %(levelname)s - %(message)s")
    file_handler.setFormatter(file_formatter)
    logger.addHandler(file_handler)

    return logger


def ctr(c=None, t=None, r=None):
    if c == "唱" and t == "跳" and r == "RAP":
        logger.info("你太美!")
    else:
        1 / 0


if __name__ == '__main__':
    logger = get_logger(level=logging.DEBUG)
    ctr("唱", "跳", "RAP")
    try:
        ctr()
    except Exception as e:
        logger.exception("执行出错")  # 自动带 traceback



小结

场景

推荐写法

快速调试

logging.basicConfig()

项目标准日志

get_logger() 封装

自动化日志记录

info / error / exception

控制台 + 文件双输出

logger + handler

记住一句话:print 只能看,logging 能分析!



下期预告


每天一个 Python 库:argparse 命令行参数解析,给脚本配上交互能力!



点关注点赞不迷路,后续更新更多自动化测试经验,我们一起成长!

欢迎留言交流:你在用 logging 吗?都用来记录哪些信息?


点击头像,查看更多文章系列

下一期更精彩,不见不散!

相关推荐

win7升级win10要留多少空间(windows7升级windows10需要多长时间)

win7电脑在系统已经激活并且开启系统更新的情况下,符合条件的系统会在右下角弹出windows10免费升级,直接点击确定就开始升级了。或者下载win10安助手,运行软件后会自动下载windows1...

国外比较开放的浏览器(国外比较开放的浏览器推荐)

1、打开控制面板。2、点击“检查防火墙状态”。3、点击左侧“高级设置”。4、选中“入栈规则”。5、右侧点击“新建规则”。6、选择“端口”。7、选择“TCP”,选中“特定端口”并输入你要开发的端口,或者...

一健ghost下载(一键ghost v2015.07.05)

你的是原版镜像,当然无法识别。。你可以使用微软usb工具。将镜像写入U盘或光盘。

纯净无毒的win7下载(有没有纯净的win7系统)

下面提供的是微软发布的Windows7各版本光盘ISO镜像下载地址,原始文件均来源自MSDN,和零-售彩盒版本光盘内容完全一致。请放心下载。(如果需要光盘的买家,请无视以下内容)下...

ie浏览器文件损坏怎么修复(ie浏览器破坏怎么恢复)

可以在浏览记录里面查到。重新下载一次就行了如果你在IE浏览器里面下载的文件被你不小心删掉了,而且这个文件对你来说很重要,你可以打开你的IE浏览器选择历史记录,在历史记录里面就可以找到相关的下载的地方,...

电脑没音量是什么原因(电脑没音量是什么原因造成的)

电脑突然没有声音可能是由于以下原因:1.音量设置被关闭或静音;2.音频驱动程序出现问题或需要更新;3.音频设备连接问题,例如音频插头没有插好或者有问题;4.操作系统的声音设置出现问题。解决方法包括检查...

电脑蓝屏u盘装系统教程(电脑蓝屏系统u盘怎么装系统)

dell电脑蓝屏用U盘重装系统方法,1在需要重装的电脑上插入启动U盘,开机并不断按下U盘启动快捷键。2在进入系统启动菜单中选择带有USB字样的选项并回车。3进入系统引导选项界面,选择Windows1...

系统之家官网纯净版(系统之家首页)

我现在用的就是系统之家的win7,以前用的是系统之家纯净版的xp,纯净版的好处就是没有预装的软件,缺点就是有些东西要自己装,包括有些软件必须的东西。装个游戏又要装这个又要装那个的很麻烦,我现在都是安装...

声卡正常但是麦克风没有声音

1、检查声卡、连接线,以及音箱等设备是否连接正常;运行杀毒软件进行杀毒;2、右击“我的电脑”----“属性”---“硬件”----“设备管理器”,打开“声音、视频和游戏控制器”有无问题,即看前面有没有...

coreldraw教程自学(coreldraw零基础教学视频)

1、CDR是矢量软件,国内印刷业和部分设计用的较多;2、基础入门操作:A、看你用在具体的哪个细分行业,如印刷排版方面、户外室内喷绘方面、图形设计方面、字体设计等等……输出的要求不一样,其他基本一样...

cad2010序列号和密钥激活码免费

回答如下:不可以,CAD2010序列号和密钥是两个不同的概念。序列号是一个唯一的标识符,用于识别软件产品的副本。而密钥是一个加密字符串,用于验证软件副本的合法性。在安装CAD2010时,需要输入正确的...

笔记本电脑联想好还是惠普好

惠普和联想为全球名列前茅的电脑品牌,其中惠普为美国品牌,联想为中国品牌。联想作为一个后起之秀,当年通过收购thankpad品牌,走向全球。电脑中又分出多种风格的子品牌,有的注重游戏性能,有的注重轻薄商...

手机和电脑怎么连接(苹果手机和电脑怎么连接)
  • 手机和电脑怎么连接(苹果手机和电脑怎么连接)
  • 手机和电脑怎么连接(苹果手机和电脑怎么连接)
  • 手机和电脑怎么连接(苹果手机和电脑怎么连接)
  • 手机和电脑怎么连接(苹果手机和电脑怎么连接)
如何安装路由器步骤(安装路由器操作步骤)

路由器安装设置共分两个步骤,依次是”路由器与光猫“串联,“宽带账号写入路由器”即可,方法如下:?步骤一首先将路由器与光猫串联,用网线一端连接至“光猫”的LAN端口,另一端连接至“路由器”的WAN端口“...

iphone序列号验机官网验机(iphone序列号验机官网验机免费)
  • iphone序列号验机官网验机(iphone序列号验机官网验机免费)
  • iphone序列号验机官网验机(iphone序列号验机官网验机免费)
  • iphone序列号验机官网验机(iphone序列号验机官网验机免费)
  • iphone序列号验机官网验机(iphone序列号验机官网验机免费)

取消回复欢迎 发表评论: