如何在Python中引发异常,以便稍后可以通过except块捕获它?
当前回答
引发异常的另一种方法是使用断言。您可以使用断言来验证条件是否得到满足。如果没有,那么它将引发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。有关详细信息,请查看此处。
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))
首先阅读现有答案,这只是一个附录。
请注意,可以使用或不使用参数引发异常。
例子:
raise SystemExit
退出程序,但您可能想知道发生了什么。所以你可以用这个。
raise SystemExit("program exited")
这将在关闭程序之前将“程序退出”打印为标准错误。
您可能还想引发自定义异常。例如,如果您正在编写一个库,那么为您的模块创建一个基本异常类,然后创建自定义子异常是一个非常好的做法。
您可以这样实现:
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等)继承自定义异常类。
如果您不关心引发哪个错误,可以使用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,因此它会引发错误,但为了让它有一个我们希望引发的文本,我们添加了一个逗号并指定了我们想要的错误文本。在本例中,我编写了手动引发的错误,这将使用该文本引发该错误。
不要这样做。提出一个简单的异常绝对不是正确的做法;请看Aaron Hall出色的回答。
再也没有比这更像Python了:
raise Exception("I know Python!")
将异常替换为要引发的特定类型的异常。
如果您想了解更多信息,请参阅Python的raise语句文档。
推荐文章
- 证书验证失败:无法获得本地颁发者证书
- 当使用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中获得所有直接子目录