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

1. 警告不是异常

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

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

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

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

2. 警告能捕获吗

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

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

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

 

3. 捕获警告方法一

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

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

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

import warnings
warnings.filterwarnings('error')    

try:
    warnings.warn("deprecated", DeprecationWarning)
except Warning as e:
    print(e)

运行后,效果如下

 

4. 捕获警告方法二

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

import warnings

try:
    warnings.warn("deprecated", DeprecationWarning)
except Warning as e:
    print(e)

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

$ python3 -W error demo.py
deprecated

5. 捕获警告方法三

除了上面的方法之外 ,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)

运行后,效果如下

 

在这里还是要推荐下我自己建的Python学习群:705933274,群里都是学Python的,如果你想学或者正在学习Python ,欢迎你加入,大家都是软件开发党,不定期分享干货(只有Python软件开发相关的),包括我自己整理的一份2021最新的Python进阶资料和零基础教学,欢迎进阶中和对Python感兴趣的小伙伴加入!

 

### Python 中的异常捕获与处理 在 Python 编程语言中,`try`, `except`, 和 `finally` 是用来实现异常处理的核心结构。这些关键字允许开发者编写能够优雅应对错误情况的程序。 #### 基本概念 当一段代码可能会抛出异常时,可以将其放置在一个 `try` 块中[^1]。如果该代码块中的任何部分引发了异常,则会跳转到对应的 `except` 部分执行特定的操作[^3]。如果没有发生异常,则继续正常运行后续代码。 #### Try 和 Except 的基本语法 以下是标准的 `try...except` 结构及其工作方式: ```python try: # 可能引发异常的代码 pass except ExceptionType as e: # 异常处理逻辑 print(f"发生了 {ExceptionType.__name__} 错误: {e}") ``` 此模式下,`ExceptionType` 表示要捕捉的具体异常类型;而变量名 `e` 则保存了关于这个具体实例的信息。 #### 实际应用案例 下面给出一个具体的例子展示如何利用 `try...except` 来管理潜在问题: ```python def divide_numbers(a, b): try: result = a / b except ZeroDivisionError as error_message: print("除数不能为零:", str(error_message)) return None else: print("计算成功!") return result print(divide_numbers(10, 2)) # 输出应为5.0并打印消息 print(divide_numbers(10, 0)) # 将触发ZeroDivisionError并显示自定义警告信息 ``` 上述脚本展示了两个场景下的行为差异——一个是正常的算术运算结果返回,另一个则是针对非法输入提供了友好的反馈机制而不是让整个应用程序崩溃[^4]。 #### Finally 子句的作用 无论是否出现了异常,在某些情况下我们希望确保某段清理型代码总会被执行。这可以通过附加一个 `finally:` 节点来达成目的。即使存在未被捕获异常或者提前退出循环等情况,这里的指令仍然会被调用一次。 ```python file_object = open('example.txt', 'r') try: data = file_object.read() except IOError: print("无法读取文件") finally: file_object.close() print("无论如何都会关闭文件对象.") ``` 在这个片段里,“无论如何都会关闭文件对象.”这条语句总是会在最后输出,即便打开文件失败也不会影响它被妥善释放资源的过程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值