python模块—log

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:

 日志是我们排查问题的关键利器,写好日志记录,当我们发生问题时,可以快速定位代码范围进行修改。Python有给我们开发者们提供好的日志模块

1.日志模块:logging

例子:

import logging

logging.debug("This is debug message")

logging.info("This is info message")

logging.warning("This is warning message")

logging.error("This is error message")

logging.critical("This is critical message")


结果:

WARNING:root:This is warning message

ERROR:root:This is error message

CRITICAL:root:This is critical message


说明:级别由上往下,依次升高,默认为info,所以只打印级别更高的日志信息


2.通过logging.basicConfig函数,提升日志级别至debug

函数说明:

level:        设置日志级别,默认为logging.WARNING

filename:      指定日志文件名。

filemode:      和file函数意义相同,指定日志文件的打开模式,'w'或'a'


format:       指定输出的格式和内容,format可以输出很多有用信息:

%(levelname)s:  打印日志级别名称

%(filename)s:   打印当前执行程序名 

%(funcName)s:   打印日志的当前函数

%(lineno)d:    打印日志的当前行号

%(asctime)s:    打印日志的时间

%(thread)d:     打印线程ID

%(process)d:    打印进程ID

%(message)s:    打印日志信息


datefmt:       指定时间格式,同time.strftime()

stream:       指定将日志的输出流,可以指定输出到sys.stderr,sys.stdout或者文件,默认输出到sys.stderr,当stream和filename同时指定时,stream被忽略

logging.getLogger([name]): 创建一个日志对象


例子:

import logging

logging.basicConfig(level=logging.DEBUG, format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',datefmt=' %Y/%m/%d %H:%M:%S'filename='mytest.log'filemode='w')

logger = logging.getLogger(__name__)

logging.debug("This is debug message")

logging.info("This is info message")

logging.warning("This is warning message")

logging.error("This is error message")

logging.critical("This is critical message")


结果:

目录下产生一个名为mytest.log文件,内容为:

2017/10/24 16:30:23 a1.python.py[line:436] DEBUG This is debug message

2017/10/24 16:30:23 a1.python.py[line:437] INFO This is info message

2017/10/24 16:30:23 a1.python.py[line:438] WARNING This is warning message

2017/10/24 16:30:23 a1.python.py[line:439] ERROR This is error message

2017/10/24 16:30:23 a1.python.py[line:440] CRITICAL This is critical message


说明:返回一个logger实例,如果没有指定name,返回root logger;只要name相同,返回的logger实例都是同一个而且只有一个,即name和logger实例是一一对应的。这意味着,无需把logger实例在各个模块中传递。只要知道name,就能得到同一个logger实例。

logging.getLogger(__name__) 在上述实例中__name__就指的是__main__










本文转自 huangzp168 51CTO博客,原文链接:http://blog.51cto.com/huangzp/1980246,如需转载请自行联系原作者
相关实践学习
通过日志服务实现云资源OSS的安全审计
本实验介绍如何通过日志服务实现云资源OSS的安全审计。
目录
相关文章
|
17天前
|
安全 大数据 程序员
Python operator模块的methodcaller:一行代码搞定对象方法调用的黑科技
`operator.methodcaller`是Python中处理对象方法调用的高效工具,替代冗长Lambda,提升代码可读性与性能。适用于数据过滤、排序、转换等场景,支持参数传递与链式调用,是函数式编程的隐藏利器。
64 4
|
11天前
|
存储 数据库 开发者
Python SQLite模块:轻量级数据库的实战指南
本文深入讲解Python内置sqlite3模块的实战应用,涵盖数据库连接、CRUD操作、事务管理、性能优化及高级特性,结合完整案例,助你快速掌握SQLite在小型项目中的高效使用,是Python开发者必备的轻量级数据库指南。
116 0
|
2月前
|
存储 安全 数据处理
Python 内置模块 collections 详解
`collections` 是 Python 内置模块,提供多种高效数据类型,如 `namedtuple`、`deque`、`Counter` 等,帮助开发者优化数据处理流程,提升代码可读性与性能,适用于复杂数据结构管理与高效操作场景。
104 0
|
11月前
|
开发者 Python
如何在Python中管理模块和包的依赖关系?
在实际开发中,通常会结合多种方法来管理模块和包的依赖关系,以确保项目的顺利进行和可维护性。同时,要及时更新和解决依赖冲突等问题,以保证代码的稳定性和可靠性
321 62
|
3月前
|
数据安全/隐私保护 Python
抖音私信脚本app,协议私信群发工具,抖音python私信模块
这个实现包含三个主要模块:抖音私信核心功能类、辅助工具类和主程序入口。核心功能包括登录
|
6月前
|
Python
Python教程:os 与 sys 模块详细用法
os 模块用于与操作系统交互,主要涉及夹操作、路径操作和其他操作。例如,`os.rename()` 重命名文件,`os.mkdir()` 创建文件夹,`os.path.abspath()` 获取文件绝对路径等。sys 模块则用于与 Python 解释器交互,常用功能如 `sys.path` 查看模块搜索路径,`sys.platform` 检测操作系统等。这些模块提供了丰富的工具,便于开发中处理系统和文件相关任务。
243 14
|
10月前
|
Python
Python Internet 模块
Python Internet 模块。
212 74
|
7月前
|
人工智能 自然语言处理 Shell
[oeasy]python070_如何导入模块_导入模块的作用_hello_dunder_双下划线
本文介绍了如何在Python中导入模块及其作用,重点讲解了`__hello__`模块的导入与使用。通过`import`命令可以将外部模块引入当前环境,增强代码功能。例如,导入`__hello__`模块后可输出“Hello world!”。此外,还演示了如何使用`help()`和`dir()`函数查询模块信息,并展示了导入多个模块的方法。最后,通过一个实例,介绍了如何利用`jieba`、`WordCloud`和`matplotlib`模块生成词云图。总结来说,模块是封装好的功能部件,能够简化编程任务并提高效率。未来将探讨如何创建自定义模块。
87 8
|
7月前
|
缓存 Shell 开发工具
[oeasy]python071_我可以自己做一个模块吗_自定义模块_引入模块_import_diy
本文介绍了 Python 中模块的导入与自定义模块的创建。首先,我们回忆了模块的概念,即封装好功能的部件,并通过导入 `__hello__` 模块实现了输出 "hello world!" 的功能。接着,尝试创建并编辑自己的模块 `my_file.py`,引入 `time` 模块以获取当前时间,并在其中添加自定义输出。
105 5
|
11月前
|
算法 数据安全/隐私保护 开发者
马特赛特旋转算法:Python的随机模块背后的力量
马特赛特旋转算法是Python `random`模块的核心,由松本真和西村拓士于1997年提出。它基于线性反馈移位寄存器,具有超长周期和高维均匀性,适用于模拟、密码学等领域。Python中通过设置种子值初始化状态数组,经状态更新和输出提取生成随机数,代码简单高效。
271 63

热门文章

最新文章

推荐镜像

更多