如何在Python中引发异常,以便稍后可以通过except块捕获它?
当前回答
需要注意的是:有时确实需要处理一般异常。如果您正在处理一堆文件并记录错误,您可能希望捕获文件发生的任何错误,记录它,然后继续处理其余文件。在这种情况下
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))
不要这样做。提出一个简单的异常绝对不是正确的做法;请看Aaron Hall出色的回答。
再也没有比这更像Python了:
raise Exception("I know Python!")
将异常替换为要引发的特定类型的异常。
如果您想了解更多信息,请参阅Python的raise语句文档。
如果您不关心引发哪个错误,可以使用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,因此它会引发错误,但为了让它有一个我们希望引发的文本,我们添加了一个逗号并指定了我们想要的错误文本。在本例中,我编写了手动引发的错误,这将使用该文本引发该错误。
在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
您可能还想引发自定义异常。例如,如果您正在编写一个库,那么为您的模块创建一个基本异常类,然后创建自定义子异常是一个非常好的做法。
您可以这样实现:
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中的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'的模块