文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

python的日志简单使用

2023-01-31 06:57

关注
开始一个项目的时候总是匆匆的写了代码,但是有时候会发现一个问题,那就是经常会为一个很长时间才出现一次的bug感到很苦恼,如果没有及时捕捉的话,那还要浪费很多时间去重现,再纠正,还好python有比较方便的日志供使用,logging模块


import logging

def getFileLogger(name):
    logger = logging.getLogger(name)
    hdlr = logging.FileHandler(name)
    formatter = logging.Formatter('[%(asctime)s] %(levelname)s : %(message)s')
    hdlr.setFormatter(formatter)
    logger.addHandler(hdlr)
    logger.setLevel(LOGLEVEL)
    logger.disabled = True
    return logger, hd

def getConsoleLogger(name):
    logger = logging.getLogger()
    logger.setLevel(LOGLEVEL)
    formatter = logging.Formatter('[%(asctime)s] %(levelname)s : %(message)s')
    hd = logging.StreamHandler()
    hd.setFormatter(formatter)
    hd.setLevel(LOGLEVEL)
    logger.disabled = True
    return logger, hd

这两个函数都是封装了logging模块的,前者为建立一个文件的logging,后者是直接在控制台输出,建立一个logging的时候同时要建立一个句柄,也就是hdlr,当程序不需要日志的时候要删除创建的句柄和释放logging,这样避免占用资源或者出现重复的打印,这种现象在多线程打印的日志的时候经常出现,粗心导致,formatter命令可以格式化logging,这样打印的东西很漂亮和工整,使用的时候就调用这两个函数直接返回一个可用的logger和句柄,有了日志,就可以在很多必要的地方加上输出,以防备bug的出现,并且能及时捕捉,及时分析。记性不好,写在这里,忘了的时候可以查查,节省时间,呵呵
阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

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

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

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

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

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

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

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