你是否是常常在使用一些系统库或者第三方模块的时候,会出现一些既不是异常也不是错误的警告信息?python
这些警告信息,有时候很是多,对于新手容易形成一些误判,觉得是程序出错了。shell
实则否则,异常和错误,都是程序出现了一些问题,可是警告不一样,他的紧急程度很是之低,以至于大多数的警告都是能够直接忽略的。bash
若是不想显示这些告警信息,能够直接加上参数 -W ignore
参数,就不会再显示了。markdown
能捕获的只有错误异常,可是经过一系列的操做后,你能够将这些警告转化为异常。oop
这样一来,你就能够像异常同样去捕获他们了。ui
在不进行任何设置的状况下,警告会直接打印在终端上。spa
在 warnings 中有一系列的过滤器。code
值 | 处置 |
---|---|
"default" |
为发出警告的每一个位置(模块+行号)打印第一个匹配警告 |
"error" |
将匹配警告转换为异常 |
"ignore" |
从不打印匹配的警告 |
"always" |
老是打印匹配的警告 |
"module" |
为发出警告的每一个模块打印第一次匹配警告(不管行号如何) |
"once" |
不管位置如何,仅打印第一次出现的匹配警告 |
当你指定为 error 的时候,就会将匹配警告转换为异常。orm
以后你就能够经过异常的方式去捕获警告了。教程
import warnings
warnings.filterwarnings('error')
try:
warnings.warn("deprecated", DeprecationWarning)
except Warning as e:
print(e)
复制代码
运行后,效果以下
若是你不想对在代码中去配置将警告转成异常。
import warnings
try:
warnings.warn("deprecated", DeprecationWarning)
except Warning as e:
print(e)
复制代码
能够在执行的时候,只要加上一个参数 -W error
,就能够实现同样的效果
$ python3 -W error demo.py
deprecated
复制代码
除了上面的方法以外 ,warnings 还自带了个捕获警告的上下文管理器。
当你加上 record=True
它会返回一个列表,列表里存放的是全部捕获到的警告,我将它赋值为 w
,而后就能够将它打印出来了。
import warnings
def do_warning():
warnings.warn("deprecated", DeprecationWarning)
with warnings.catch_warnings(record=True) as w:
do_warning()
if len(w) >0:
print(w[0].message)
复制代码
运行后,效果以下
文章最后给你们介绍三个我本身写的在线文档:
第一个文档:PyCharm 中文指南 1.0 文档
花了两个多月的时间,整理了 100 个 PyCharm 的使用技巧,为了让新手可以直接上手,我花了不少的时间录制了上百张 GIF 动图,有兴趣的前往在线文档阅读。
第二个文档:PyCharm 黑魔法指南 1.0 文档
系统收录各类 Python 冷门知识,Python Shell 的多样玩法,使人疯狂的 Python 炫技操做,Python 的超详细进阶知识解读,很是实用的 Python 开发技巧等。
第三个文档:Python 中文指南 1.0 文档
花了三个月时间写的一本 适合零基础入门 Python 的全中文教程,搭配大量的代码案例,让初学者对 代码的运做效果有一个直观感觉,教程既有深度又有广度,每篇文章都会标内容的难度,是基础仍是进阶的,可供读者进行选择,是一本可贵的 Python 中文电子教程。