python 日志模块
2023-09-27 14:27:40 时间
之前项目中用的是工具组做的日志模块,用的久了,脑袋里就懒得思考这是如何实现的。毕竟菊厂的开发,忙成狗,不是我所负责的自然只是看看会用就行了。最近开始奋发图强,自然要好好看下基础的东西。
以前做java开发时候知道java有个log4j的日志模块,用着还不错。我在python中找到它有自己的日志模块logging,另外搜索log4python,发现简书上有人对这个评价一般,有贴出来代码和配置,所以主要还是先看python自带的。
import logging.handlers LOG_FORMAT = "%(asctime)s - [%(levelname)s] - %(message)s" # logging.basicConfig(filename="test.log", level=logging.DEBUG, format=LOG_FORMAT) my_logger = logging.getLogger("my_loger") my_logger.setLevel(logging.DEBUG) console_handler = logging.StreamHandler() log_format = logging.Formatter(LOG_FORMAT) console_handler.setFormatter(log_format) file_handler = logging.FileHandler("my_test.log",encoding="utf-8") my_logger.addHandler(console_handler) my_logger.addHandler(file_handler) if __name__ == "__main__": my_logger.debug("this is debug log") my_logger.info("this is info log")
通过自带的logging模块来看,日志可以通过不同的handler同时打印到控制台和文件,而且各自用各自自己的日志格式,所以,是可以满足日常开发使用的。
在使用时候,可以通过logging.basicConfig来全局配置,后续用logging.debug()这种语句来打印日志;也可以用logging.getLogger实例化一个日志对象,添加不同的handler,后面再用logging实例化出来的对应打印。
在控制台打印上,可以用StreamHandler类,默认打印到std.err; 打印到文件中,可以用FileHandler,或者更实用的RotatingFileHandler,按照官方文档所说,RotatingFileHandler在日志文件达到了指定大小之后可以分割文件。
相关文章
- python爬虫Jenkins编译失败的日志
- 5 分钟,教你用 Docker 部署一个 Python 应用
- Python GUI之tkinter窗口视窗教程大集合(看这篇就够了) JAVA日志的前世今生 .NET MVC采用SignalR更新在线用户数 C#多线程编程系列(五)- 使用任务并行库 C#多线程编程系列(三)- 线程同步 C#多线程编程系列(二)- 线程基础 C#多线程编程系列(一)- 简介
- python清除数据库错误日志
- python import logging日志
- 【华为OD机试真题 python】日志限流【2023 Q1 | 100分】
- 【华为OD机试真题 python】日志首次上报最多积分【2022 Q4 | 100分】
- 【华为OD机试真题 python】连续出牌数量【2022 Q4 | 200分】
- 【华为OD机试真题 python】 运维日志排序【2022 Q4 | 100分】
- 零基础自学Python真的有这么简单?(赠送学习路线及教程)
- python模块之imghdr检测图片类型
- 最简单的让Python程序运行完后命令行窗口(cmd窗口)不自动关闭的方法
- python logging日志处理详解
- 《 Python树莓派编程》——2.4 Linux中的shell
- python解析基于xml格式的日志文件
- 【Python】【日志】log/logging
- python 写入日志的问题 UnicodeEncodeError: 'gbk' codec can't encode character 'xbb' in position 0: illegal multibyte sequence
- python字典获取最大值的键的值
- 概率分布之间的距离度量以及python实现(四)
- 《树莓派Python编程入门与实战》——第3章 搭建编程环境
- 《Python编程快速上手——让繁琐工作自动化》——1.8 习题
- (转)python中用logging实现日志滚动和过期日志删除
- python之打印日志logging
- python ide
- 小学Python编程 ——迷宫
- Python 基础 之 zipfile 文件夹压缩/解压方法的简单整理
- Python 常见问题 之 AttributeError: module ‘select‘ has no attribute ‘epoll‘
- python日志屏幕输出、文件滚动保存、屏幕及文件日志级别设置、颜色标记