码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • python学习-----logging模块


    第一种方法:

    编程方法:

    1. import logging
    2. #记录器
    3. logger = logging.getLogger('applog')
    4. logger.setLevel('DEBUG')
    5. #必须设置为两个handler中级别更低的
    6. #处理器handler
    7. consoleHandler = logging.StreamHandler()
    8. consoleHandler.setLevel(logging.DEBUG)
    9. #没有给handler指定日志级别,将使用logger的级别
    10. fileHandler = logging.FileHandler(filename='addDemo.log')
    11. fileHandler.setLevel(logging.INFO)
    12. #
    13. # #formatter格式
    14. formatter = logging.Formatter('%(asctime)s - %(funcName)s - %(levelname)s - %(message)s')
    15. #里面的8,10实现了占位对齐
    16. #给处理器设置格式
    17. consoleHandler.setFormatter(formatter)
    18. fileHandler.setFormatter(formatter)
    19. #记录器要设置处理器
    20. logger.addHandler(consoleHandler)
    21. logger.addHandler(fileHandler)
    22. #定义一个过滤器
    23. flt = logging.Filter("cn.cccb")
    24. #关联过滤器
    25. # logger.addFilter(flt)
    26. fileHandler.addFilter(flt)
    27. #打印日志的代码
    28. logger.debug("this is debug log")
    29. logger.info("this is info log")
    30. logger.warning("this is warning log")
    31. logger.error("this is error log")
    32. logger.critical("this is critical log")

    第二种方法:

    配置文件方法:

    logging.conf

    1. [loggers]
    2. keys=root,applog
    3. [handlers]
    4. keys=fileHandler,consoleHandler
    5. [formatters]
    6. keys=simpleFormatter
    7. [logger_root]
    8. level=DEBUG
    9. handlers=consoleHandler
    10. [logger_applog]
    11. level=DEBUG
    12. handlers=fileHandler,consoleHandler
    13. qualname=applog
    14. propagate=0
    15. [handler_consoleHandler]
    16. class=StreamHandler
    17. args=(sys.stdout,)
    18. level=DEBUG
    19. formatter=simpleFormatter
    20. [handler_fileHandler]
    21. class=handlers.TimedRotatingFileHandler
    22. args=('applog.log','midnight',3600,0)
    23. level=DEBUG
    24. formatter=simpleFormatter
    25. [formatter_simpleFormatter]
    26. format=%(asctime)s|%(levelname)8s|%(filename)s[:%(lineno)d]|%(message)s
    27. datefmt=%Y-%m-%d %H:%M:%S

    main

    1. import logging.config
    2. logging.config.fileConfig("logging.conf")
    3. rootlogger = logging.getLogger()
    4. rootlogger.debug('debug')
    5. logger = logging.getLogger('applog')
    6. logger.debug('debug2')
    7. a = 'abc'
    8. try:
    9. int(a)
    10. except Exception as e:
    11. # logger.error(e)
    12. logger.exception(e)

    参考文件

    标准库系列:logging 日志打印 - 小康要好好学习 - 博客园

    Python基础之标准库logging 你还在用print来调试程序吗,OUT啦_哔哩哔哩_bilibili

  • 相关阅读:
    重要变更 | Hugging Face Hub 的 Git 操作不再支持使用密码验证
    面试题08.05.递归算法
    算法分析与设计CH16:贪心算法——活动选择问题、背包问题(分数背包/0-1背包)、哈夫曼编码
    Spring Boot、Nacos配置文件的优先级
    Qtday1
    旧系统改造
    信道复用技术
    NB15 牛群编号的回文顺序II
    jsp汽车销售管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目
    20天零基础自学Python | Day6 运算符大全
  • 原文地址:https://blog.csdn.net/qq_28057379/article/details/126783084
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号