博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python异常处理
阅读量:4687 次
发布时间:2019-06-09

本文共 1212 字,大约阅读时间需要 4 分钟。

当写python程序时,我们打印了一个没有定义过的变量,,那么这是会发生什么样的情况呢?

运行时会报错,但是我们又不想让我们的程序终止,那怎么办的?

加上异常处理,再比如一个列表的长度是5,我们利用索引取值时,索引写的是5,那这时也会报错。

而常见的异常则是下面这几种

AttributeError 试图访问一个对象没有的属性,比如foo.x,但是foo没有属性xIOError 输入/输出异常;基本上是无法打开文件ImportError 无法引入模块或包;基本上是路径问题或名称错误IndentationError 语法错误(的子类) ;代码没有正确对齐IndexError 下标索引超出序列边界,比如当x只有三个元素,却试图访问x[5]KeyError 试图访问字典里不存在的键KeyboardInterrupt Ctrl+C被按下NameError 使用一个还未被赋予对象的变量SyntaxError Python代码非法,代码不能编译(个人认为这是语法错误,写错了)TypeError 传入对象类型与要求的不符合UnboundLocalError 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量,导致你以为正在访问它ValueError 传入一个调用者不期望的值,即使值的类型是正确的

那么我们怎么来捕获可能发生的异常呢?

try:    可能会抛出异常的代码块except 异常的类型 as e:    捕获到异常之后的处理方式

举个例子

s1 = 'hello'try:    int(s1)except ValueError as e:    print(e)

上面这个例子中s1是一个字符串,正常情况下将它转化数字时会报错,但是通过异常处理之后,程序不会由于抛出异常而终止,而是会交由print(e)进行处理,将会打印出下面这句话

invalid literal for int() with base 10: 'hello'

多分支异常处理

s1 = 'hello'try:    int(s1)except KeyError as e:    print(e)except Exception as e:    print(e)finally:    print('无论是否有异常我都会执行')

 一个具备多分支的异常处理可以处理多种抛出的异常,而Except Exception as e则可以捕获所有的异常,finally则是无论程序是否出现异常,都会执行的。

异常的继承,上面这些异常都是通过继承实现的,通过继承Exception 而来,而Exception又是继承的BaseException。

可以说各种常见的异常均是继承来自同一个祖先,BaseException。

 

转载于:https://www.cnblogs.com/June-King/p/10596198.html

你可能感兴趣的文章
SVN客户端访问URL失败--请求的名称有效,但是找不到请求的类型 (转载)
查看>>
通过扩展让ASP.NET Web API支持W3C的CORS规范
查看>>
开源项目Html Agility Pack实现快速解析Html
查看>>
docker和kubernetes中hostname的使用和常见问题
查看>>
js调用百度地图接口
查看>>
.net Mvc文件下载的功能,大文件下载完成之后修改数据库功能
查看>>
JDBC/XML的一些基本使用
查看>>
构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(32)-swfupload多文件上传[附源码]...
查看>>
[CLR via C#]5.4 对象哈希码和dynamic基元类型
查看>>
Contoso 大学 - 1 - 为 ASP.NET MVC 应用程序创建 EF 数据模型
查看>>
Lucene.net 实现近实时搜索(NRT)和增量索引
查看>>
Objective-C学习篇09—NSNumber与笑笑语法
查看>>
模式字符串匹配问题(KMP算法)
查看>>
读书笔记---《Docker 技术入门与实践》---为镜像添加SSH服务
查看>>
Code as IaaS for Azure : Terraform 做多一点事情
查看>>
[537.A]2019-08-03(星期六)登顶梧桐山邀请
查看>>
HDOJ,水题继续,杭电1215,七夕节。关于运算优化的数学题。
查看>>
js 递归 汉诺塔的例子
查看>>
向现有的数据库中添加文件组和数据文件
查看>>
Centos7下安装Oracle11g r2
查看>>