python logging模块打印log到指定文件

简介:

可能我们经常会使用print来输出信息到窗口,但当我们有很多个py文件需要运行,项目比

较庞大的到时候,print简直就是太low了点了。那么我们可以使用强大的logging模块,把

输出到指定的本地pc某个路径的文件中。

一、 logging的框架
1、 Loggers: 可供程序直接调用的接口,app通过调用提供的api来记录日志
2、 Handlers: 决定将日志记录分配至正确的目的地
3、 Filters:对日志信息进行过滤, 提供更细粒度的日志是否输出的判断
4、 Formatters: 制定最终记录打印的格式布局

二、 Log级别
系统默认有6个级别,优先级:

CRITICAL    50
ERROR      40
WARNING   30
INFO        20
DEBUG      10
NOTSET     0

设置要打印的log时只需要设置优先级,比如设置打印INFO,那么比INFO优先级高的WARNING/ERROR/CRITICAL都将被打印。

三、 正常的打印
python logging模块打印log到指定文件

这里只输出了ERROR和WARNING的信息,是因为logging默认的输出级别是WARNING。

四、 输出到指定文件
来看看这样写的代码:

import logging
import unittest
class lgtest(unittest.TestCase):
    logging.basicConfig(filename='../LOG/'+__name__+'.log',format='[%(asctime)s-%(filename)s-%(levelname)s:%(message)s]', level = logging.DEBUG,filemode='a',datefmt='%Y-%m-%d %I:%M:%S %p')

    def test(self):

        logging.error("这是一条error信息的打印")
        logging.info("这是一条info信息的打印")
        logging.warning("这是一条warn信息的打印")
        logging.debug("这是一条debug信息的打印")
if __name__=='__main__':
    unittest.main()

使用logging.basicConfig来指定要输出的文件以及log的输出形式、包括时间格式、日志级别等等。

Filename:指定路径的文件。这里使用了+—name—+是将log命名为当前py的文件名
Format:设置log的显示格式(即在文档中看到的格式)。分别是时间+当前文件名+log输出级别+输出的信息
Level:输出的log级别,优先级比设置的级别低的将不会被输出保存到log文档中
Filemode: log打开模式
a:代表每次运行程序都继续写log。即不覆盖之前保存的log信息。
w:代表每次运行程序都重新写log。即覆盖之前保存的log信息

五、 最终的log文档

python logging模块打印log到指定文件

文件名与py文件名相同,因为basicConfig里面使用了name来获取的。

我们来看看内容,这是运行了两次py文件的内容:

[2018-02-10 02:29:57 PM-Logout.py-ERROR:这是一条error信息的打印]
[2018-02-10 02:29:57 PM-Logout.py-INFO:这是一条info信息的打印]
[2018-02-10 02:29:57 PM-Logout.py-WARNING:这是一条warn信息的打印]
[2018-02-10 02:29:57 PM-Logout.py-DEBUG:这是一条debug信息的打印]
[2018-02-10 02:39:32 PM-Logout.py-ERROR:这是一条error信息的打印]
[2018-02-10 02:39:32 PM-Logout.py-INFO:这是一条info信息的打印]
[2018-02-10 02:39:32 PM-Logout.py-WARNING:这是一条warn信息的打印]
[2018-02-10 02:39:32 PM-Logout.py-DEBUG:这是一条debug信息的打印]
运行一次会有4个信息打印出来,因为filemode设置成了a,所以再次运行时不会覆盖

之前的log信息,就有8条信息了。

Ok,log输出到文档就这么简单。当然大家如果弄熟了可以自己写记录器、过滤器等。


本文转自niedongri 51CTO博客,原文链接:http://blog.51cto.com/laomomo/2070887,如需转载请自行联系原作者

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
24天前
|
Python
【python】python跨文件使用全局变量
【python】python跨文件使用全局变量
|
24天前
|
存储 开发者 Python
Python中的collections模块与UserDict:用户自定义字典详解
【4月更文挑战第2天】在Python中,`collections.UserDict`是用于创建自定义字典行为的基类,它提供了一个可扩展的接口。通过继承`UserDict`,可以轻松添加或修改字典功能,如在`__init__`和`__setitem__`等方法中插入自定义逻辑。使用`UserDict`有助于保持代码可读性和可维护性,而不是直接继承内置的`dict`。例如,可以创建一个`LoggingDict`类,在设置键值对时记录操作。这样,开发者可以根据具体需求定制字典行为,同时保持对字典内部管理的抽象。
|
1天前
|
JSON JavaScript 数据格式
python遍历目录文件_结合vue获取所有的html文件并且展示
python遍历目录文件_结合vue获取所有的html文件并且展示
4 0
|
3天前
|
开发者 Python
Python的os模块详解
Python的os模块详解
15 0
|
6天前
|
数据挖掘 API 数据安全/隐私保护
python请求模块requests如何添加代理ip
python请求模块requests如何添加代理ip
|
7天前
|
运维 Oracle 关系型数据库
Oracle日志文件:数据王国的“记事本”
【4月更文挑战第19天】Oracle日志文件是数据库稳定运行的关键,记录数据变更历史,用于恢复和故障处理。它们协调并发操作,确保数据一致性和完整性。日志文件实时写入操作信息并定期刷新到磁盘,便于数据恢复。然而,日志文件需备份和归档以保证安全性,防止数据丢失。日志文件,数据王国的“记事本”,默默守护数据安全。
|
7天前
|
存储 Python
用Python实现批量下载文件——代理ip排除万难
用Python实现批量下载文件——代理ip排除万难
|
8天前
|
测试技术 Python
Python 有趣的模块之pynupt——通过pynput控制鼠标和键盘
Python 有趣的模块之pynupt——通过pynput控制鼠标和键盘
|
8天前
|
JSON 关系型数据库 数据库
《Python 简易速速上手小册》第6章:Python 文件和数据持久化(2024 最新版)
《Python 简易速速上手小册》第6章:Python 文件和数据持久化(2024 最新版)
35 0
|
8天前
|
Serverless 开发者 Python
《Python 简易速速上手小册》第3章:Python 的函数和模块(2024 最新版)
《Python 简易速速上手小册》第3章:Python 的函数和模块(2024 最新版)
40 1