时间:2021-05-23
你是不是经常在使用一些系统库或者第三方模块的时候,会出现一些既不是异常也不是错误的警告信息?
这些警告信息,有时候非常多,对于新手容易造成一些误判,以为是程序出错了。
实则不然,异常和错误,都是程序出现了一些问题,但是警告不同,他的紧急程度非常之低,以致于大多数的警告都是可以直接忽略的。
如果不想显示这些告警信息,可以直接加上参数 -W ignore 参数,就不会再显示了。
能捕获的只有错误异常,但是通过一系列的操作后,你可以将这些警告转化为异常。
这样一来,你就可以像异常一样去捕获他们了。
在不进行任何设置的情况下,警告会直接打印在终端上。
在 warnings 中有一系列的过滤器。
当你指定为 error 的时候,就会将匹配警告转换为异常。
之后你就可以通过异常的方式去捕获警告了。
importwarningswarnings.filterwarnings('error')try:warnings.warn("deprecated",DeprecationWarning)exceptWarningase:print(e)运行后,效果如下
如果你不想对在代码中去配置将警告转成异常。
importwarningstry:warnings.warn("deprecated",DeprecationWarning)exceptWarningase:print(e)可以在执行的时候,只要加上一个参数 -W error ,就可以实现一样的效果
$python3-Werrordemo.pydeprecated除了上面的方法之外 ,warnings 还自带了个捕获警告的上下文管理器。
当你加上 record=True 它会返回一个列表,列表里存放的是所有捕获到的警告,我将它赋值为 w,然后就可以将它打印出来了。
importwarningsdefdo_warning():warnings.warn("deprecated",DeprecationWarning)withwarnings.catch_warnings(record=True)asw:do_warning()iflen(w)>0:print(w[0].message)运行后,效果如下
以上就是python捕获警告的三种方法的详细内容,更多关于python 捕获警告的资料请关注其它相关文章!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
python记录程序运行时间的三种方法这里提供了python记录程序运行时间的三种方法,并附有实现代码,最后进行比较,大家参考下:方法1importdateti
python版本:3.6pandas版本:0.23.4行索引索引行有三种方法,分别是locilociximportpandasaspdimportnumpyas
Python中至少有三种比较常见的方法类型,即实例方法,类方法、静态方法。它们是如何定义的呢?如何调用的呢?它们又有何区别和作用呢?且看下文。首先,这三种方法都
java实现多线程的三种方法在java中,有三种方法可以实现多线程。第一种方法:继承Thread类,重写run函数。第二种方法:实现Runnable接口,重写r
Python中有三种方式表示字符串第一种方法使用单引号(‘)用单引号括起来表示字符串,例如:str='thisisstring';printstr;第二种方法使