如何在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
块是一个很好的方法。不过,您仍然需要引发特定的异常,以便了解它们的含义。
引发异常的另一种方法是使用断言。您可以使用断言来验证条件是否得到满足。如果没有,那么它将引发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))
对于常见的情况,您需要抛出异常以响应某些意外情况,并且您从未打算捕获异常,而是简单地快速失败以使您能够在任何情况下从那里进行调试,最合乎逻辑的似乎是AssertionError:
if 0 < distance <= RADIUS:
#Do something.
elif RADIUS < distance:
#Do something.
else:
raise AssertionError("Unexpected value of 'distance'!", distance)
如果您不关心引发哪个错误,可以使用assert引发AssertionError:
>>> assert False, "Manually raised error"
Traceback (most recent call last):
File "<pyshell#24>", line 1, in <module>
assert False, "Manually raised error"
AssertionError: Manually raised error
>>>
如果条件为False,assert关键字将引发AssertionError。在本例中,我们直接指定了False,因此它会引发错误,但为了让它有一个我们希望引发的文本,我们添加了一个逗号并指定了我们想要的错误文本。在本例中,我编写了手动引发的错误,这将使用该文本引发该错误。
首先阅读现有答案,这只是一个附录。
请注意,可以使用或不使用参数引发异常。
例子:
raise SystemExit
退出程序,但您可能想知道发生了什么。所以你可以用这个。
raise SystemExit("program exited")
这将在关闭程序之前将“程序退出”打印为标准错误。
推荐文章
- python中的assertEquals和assertEqual
- 如何保持Python打印不添加换行符或空格?
- 为什么Python的无穷散列中有π的数字?
- Python 3.7数据类中的类继承
- 如何在PyTorch中初始化权重?
- 计数唯一的值在一列熊猫数据框架像在Qlik?
- 使用Pandas将列转换为行
- 从matplotlib中的颜色映射中获取单个颜色
- 将Pandas或Numpy Nan替换为None以用于MysqlDB
- 使用pandas对同一列进行多个聚合
- 使用Python解析HTML
- django MultiValueDictKeyError错误,我如何处理它
- 如何在for循环期间修改列表条目?
- 我如何在Django中创建一个鼻涕虫?
- 没有名为'django.core.urlresolvers'的模块