Python 怎么捕获警告?(注意:不是捕获异常)

开发 后端
你是不是经常在使用一些系统库或者第三方模块的时候,会出现一些既不是异常也不是错误的警告信息?

本文转载自微信公众号“Python编程时光”(Cool-Python)。

[[387401]]

1. 警告不是异常

你是不是经常在使用一些系统库或者第三方模块的时候,会出现一些既不是异常也不是错误的警告信息?

这些警告信息,有时候非常多,对于新手容易造成一些误判,以为是程序出错了。

实则不然,异常和错误,都是程序出现了一些问题,但是警告不同,他的紧急程度非常之低,以致于大多数的警告都是可以直接忽略的。

如果不想显示这些告警信息,可以直接加上参数 -W ignore 参数,就不会再显示了。

2. 警告能捕获吗

能捕获的只有错误异常,但是通过一系列的操作后,你可以将这些警告转化为异常。

这样一来,你就可以像异常一样去捕获他们了。

在不进行任何设置的情况下,警告会直接打印在终端上。

3. 捕获警告方法一

在 warnings 中有一系列的过滤器。

当你指定为 error 的时候,就会将匹配警告转换为异常。

之后你就可以通过异常的方式去捕获警告了。

  1. import warnings 
  2. warnings.filterwarnings('error')     
  3.  
  4. try: 
  5.     warnings.warn("deprecated", DeprecationWarning) 
  6. except Warning as e: 
  7.     print(e) 

运行后,效果如下

4. 捕获警告方法二

如果你不想对在代码中去配置将警告转成异常。

  1. import warnings 
  2.  
  3. try: 
  4.     warnings.warn("deprecated", DeprecationWarning) 
  5. except Warning as e: 
  6.     print(e) 

可以在执行的时候,只要加上一个参数 -W error ,就可以实现一样的效果

  1. $ python3 -W error demo.py 
  2. deprecated 

5. 捕获警告方法三

除了上面的方法之外 ,warnings 还自带了个捕获警告的上下文管理器。

当你加上 record=True 它会返回一个列表,列表里存放的是所有捕获到的警告,我将它赋值为 w,然后就可以将它打印出来了。

  1. import warnings 
  2.  
  3. def do_warning(): 
  4.     warnings.warn("deprecated", DeprecationWarning) 
  5.  
  6. with warnings.catch_warnings(record=True) as w: 
  7.     do_warning() 
  8.     if len(w) >0: 
  9.         print(w[0].message) 

运行后,效果如下

 

责任编辑:赵宁宁 来源: Python编程时光
相关推荐

2013-05-14 11:13:40

动态捕获PythonPython异常

2017-03-21 16:34:38

iOS捕获异常

2021-09-26 09:40:25

React代码前端

2022-08-16 10:44:11

Sentry前端异常

2015-02-03 14:45:55

android全局异常

2024-11-11 11:21:30

虚拟机Python跳转表

2017-05-04 21:30:32

前端异常监控捕获方案

2022-11-28 07:35:52

前端错误

2010-12-21 14:08:50

PowerShell

2009-07-15 15:09:18

2016-02-17 15:15:01

2021-01-31 11:47:08

C语言SetjmpLongjmp

2011-05-23 13:54:04

闭包

2021-01-05 07:54:55

事项trycatch

2023-12-06 09:27:46

Java程序

2020-10-13 19:04:58

Bash信号捕获Shell脚本

2016-10-20 19:07:10

Javascript事件冒泡与捕获

2018-12-24 14:03:15

SSH蜜罐

2010-02-26 10:14:25

WCF全局错误捕获

2009-12-30 14:28:06

Silverlight
点赞
收藏

51CTO技术栈公众号