返回介绍

例子:默认行为

发布于 2024-01-29 22:24:15 字数 1064 浏览 0 评论 0 收藏 0

因为Python中通过一个程序的控制流程,比英语更容易掌握,让我们运行一些例子,进一步示范异常的基础知识。前文已经提到过,try语句没有捕捉的异常会向上传递到Python进程的顶层,并执行Python默认异常处理逻辑(也就是说,Python终止执行中的程序,并打印标准出错消息)。让我们看一个例子。执行下列模块bad.py来产生一个除以零的异常。

因为程序忽略它触发的异常,Python会终止这个程序,打印一个消息。

我在Python 3.0下的一个shell窗口中运行它。消息包含了一个堆栈跟踪("Traceback")以及所引发的异常的名称和细节。堆栈跟踪按照从旧到新的顺序列出异常发生时激活状态下的所有程序的行。因为我们不是在交互模式提示符下工作,所以这种情况下文件和行号信息都有用。例如,在这里我们可以看见跟踪中最后一项发生了错误的除法:文件bad.py的第2行,即return语句。因为Python会在运行时检测所有错误,引发异常并报告,所以一般情况下,异常和错误处理及调试的想法紧密结合起来[1]

如果你做过本书例子,在过程中显然会看到过一两个异常:当文件导入或执行时(当编译器在执行时),即使是输入错误通常也会产生SyntaxError或其他异常。默认情况下,你会得到像上面那样有用的出错显示,有助于跟踪问题。通常来说,这个标准出错消息,就是解决程序代码中问题所需的一切。就更大型的调试工作而言,可以用try语句捕捉异常,或者使用第3章所介绍的并将在第35章再次概述的调试工具,例如,pdb标准库模块。

[1]出错消息和堆栈跟踪的文字可能随时间不同而略有不同。如果你的出错消息和本书的不同,也别害怕。例如,在Python 3.0的IDLE GUI中执行这个例子时,出错消息正文在文件名中显示完整的目录路径。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文