如何在Python中引发异常,以便稍后可以通过except块捕获它?
当前回答
您可能还想引发自定义异常。例如,如果您正在编写一个库,那么为您的模块创建一个基本异常类,然后创建自定义子异常是一个非常好的做法。
您可以这样实现:
class MyModuleBaseClass(Exception):
pass
class MoreSpecificException(MyModuleBaseClass):
pass
# To raise custom exceptions, you can just
# use the raise keyword
raise MoreSpecificException
raise MoreSpecificException('message')
如果您对拥有自定义基类不感兴趣,您可以从普通异常类(如exception、TypeError、ValueError等)继承自定义异常类。
其他回答
为此,您应该学习Python的raise语句。
它应该保存在试块内。
示例-
try:
raise TypeError # Replace TypeError by any other error if you want
except TypeError:
print('TypeError raised')
在Python 3中,有四种不同的语法用于引发异常:
引发异常引发异常(args)提升从original_exception引发异常(args)
1.引发异常vs.2。引发异常(args)
如果使用引发异常(args)引发异常,则在打印异常对象时将打印这些参数,如下例所示。
# Raise exception (args)
try:
raise ValueError("I have raised an Exception")
except ValueError as exp:
print ("Error", exp) # Output -> Error I have raised an Exception
# Raise exception
try:
raise ValueError
except ValueError as exp:
print ("Error", exp) # Output -> Error
3.声明提出
没有任何参数的raise语句重新引发最后一个异常。
如果您在捕获异常后需要执行一些操作,然后想要重新引发异常,那么这很有用。但是如果之前没有任何异常,那么raise语句会引发TypeError异常。
def somefunction():
print("some cleaning")
a=10
b=0
result=None
try:
result=a/b
print(result)
except Exception: # Output ->
somefunction() # Some cleaning
raise # Traceback (most recent call last):
# File "python", line 8, in <module>
# ZeroDivisionError: division by zero
4.从original_exception引发异常(args)
此语句用于创建异常链接,其中响应另一个异常而引发的异常可以包含原始异常的详细信息,如下例所示。
class MyCustomException(Exception):
pass
a=10
b=0
reuslt=None
try:
try:
result=a/b
except ZeroDivisionError as exp:
print("ZeroDivisionError -- ",exp)
raise MyCustomException("Zero Division ") from exp
except MyCustomException as exp:
print("MyException",exp)
print(exp.__cause__)
输出:
ZeroDivisionError -- division by zero
MyException Zero Division
division by zero
需要注意的是:有时确实需要处理一般异常。如果您正在处理一堆文件并记录错误,您可能希望捕获文件发生的任何错误,记录它,然后继续处理其余文件。在这种情况下
try:
foo()
except Exception as e:
print(e) # Print out handled error
块是一个很好的方法。不过,您仍然需要引发特定的异常,以便了解它们的含义。
您可能还想引发自定义异常。例如,如果您正在编写一个库,那么为您的模块创建一个基本异常类,然后创建自定义子异常是一个非常好的做法。
您可以这样实现:
class MyModuleBaseClass(Exception):
pass
class MoreSpecificException(MyModuleBaseClass):
pass
# To raise custom exceptions, you can just
# use the raise keyword
raise MoreSpecificException
raise MoreSpecificException('message')
如果您对拥有自定义基类不感兴趣,您可以从普通异常类(如exception、TypeError、ValueError等)继承自定义异常类。
对于常见的情况,您需要抛出异常以响应某些意外情况,并且您从未打算捕获异常,而是简单地快速失败以使您能够在任何情况下从那里进行调试,最合乎逻辑的似乎是AssertionError:
if 0 < distance <= RADIUS:
#Do something.
elif RADIUS < distance:
#Do something.
else:
raise AssertionError("Unexpected value of 'distance'!", distance)
推荐文章
- 证书验证失败:无法获得本地颁发者证书
- 当使用pip3安装包时,“Python中的ssl模块不可用”
- 无法切换Python与pyenv
- Python if not == vs if !=
- 如何从scikit-learn决策树中提取决策规则?
- 为什么在Mac OS X v10.9 (Mavericks)的终端中apt-get功能不起作用?
- 将旋转的xtick标签与各自的xtick对齐
- 为什么元组可以包含可变项?
- 如何合并字典的字典?
- 如何创建类属性?
- 不区分大小写的“in”
- 在Python中获取迭代器中的元素个数
- 解析日期字符串并更改格式
- 使用try和。Python中的if
- 如何在Python中获得所有直接子目录