如何在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等)继承自定义异常类。
其他回答
需要注意的是:有时确实需要处理一般异常。如果您正在处理一堆文件并记录错误,您可能希望捕获文件发生的任何错误,记录它,然后继续处理其余文件。在这种情况下
try:
foo()
except Exception as e:
print(e) # Print out handled error
块是一个很好的方法。不过,您仍然需要引发特定的异常,以便了解它们的含义。
首先阅读现有答案,这只是一个附录。
请注意,可以使用或不使用参数引发异常。
例子:
raise SystemExit
退出程序,但您可能想知道发生了什么。所以你可以用这个。
raise SystemExit("program exited")
这将在关闭程序之前将“程序退出”打印为标准错误。
在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
对于常见的情况,您需要抛出异常以响应某些意外情况,并且您从未打算捕获异常,而是简单地快速失败以使您能够在任何情况下从那里进行调试,最合乎逻辑的似乎是AssertionError:
if 0 < distance <= RADIUS:
#Do something.
elif RADIUS < distance:
#Do something.
else:
raise AssertionError("Unexpected value of 'distance'!", distance)
引发异常的另一种方法是使用断言。您可以使用断言来验证条件是否得到满足。如果没有,那么它将引发AssertionError。有关详细信息,请查看此处。
def avg(marks):
assert len(marks) != 0, "List is empty."
return sum(marks)/len(marks)
mark2 = [55,88,78,90,79]
print("Average of mark2:", avg(mark2))
mark1 = []
print("Average of mark1:", avg(mark1))
推荐文章
- 使用python创建一个简单的XML文件
- APT命令行界面式的yes/no输入?
- 如何打印出状态栏和百分比?
- 在Python中获取大文件的MD5哈希值
- 在Python格式字符串中%s是什么意思?
- 如何循环通过所有但最后一项的列表?
- python用什么方法避免默认参数为空列表?
- 导致java.lang.VerifyError错误的原因
- ValueError: numpy。Ndarray大小改变,可能表示二进制不兼容。期望从C头得到88,从PyObject得到80
- Anaconda /conda -安装特定的软件包版本
- 我在哪里调用Keras的BatchNormalization函数?
- 打印测试执行时间并使用py.test锁定缓慢的测试
- 插入一行到熊猫数据框架
- 要列出Pandas DataFrame列
- 在Django模型中存储电话号码的最佳方法是什么?