try/except/else语句

这些语句的一般的格式如下图所示

其中try中定义了主要执行的动作。except中定义了try语句当中发生异常的处理器。else定义了没有发生异常时候的处理器。

try语句运行的方式:try语句启动的时候,pyton会标识当前的程序环境,如果有异常发生,才返回这里。try首行下面的语句先被执行,然后根据执行的程序的情况,发生下面不同的动作:

-try里面的代码块的确发生异常,python就会跳回try,执行第一个符合引发异常的except字句下面的语句。当except执行后,控制权会到整个try语句后(try/except/else所有语句)继续执行。

-try里面的代码块发生异常,但是没有符合的except字据,那么异常会向上传递。

-try里面的代码没有异常,python会执行else行下的语句,控制权会在整个try语句下继续。

try语句分句

-在python2.5开始,finally可以和except和else出现在同一个语句当中,在2.5以前,finally只能单独的和try结合使用。

-excpet: 这种形式可以捕获任何形式的异常,是一种通用的功能。except Exception:  捕获一个名为Exception的异常,效果几乎和空的except具有相同的效果,但是忽略和系统退出相关的异常。

-一旦捕获了异常,控制权会在捕捉的地方继续向下(也就是在try之后),没有直接的方式可以回到异常发生的地方那个,可以运行下面的代码:

try:
print('A')
raise IndexError
print('B')
except IndexError:
print('C')
print('D')

输出结果如下:

A
C
D

可以发现,在捕获到IndexError异常以后,try语句里面的内容不会向下执行(即不会输出‘B’),而是在整个try语句后继续运行。

try/finally语句

-当try代码块当中有异常的时候,python会回来运行finally里面的代码块,但是紧接着会把异常向上传递,传到较高等级的try或者顶层默认处理器,程序不会在try语句下继续执行。和except不同的是,finally不会终止异常,而是在finally代码块执行后,一直处于发生状态

-try/finally最典型的另个应用场景是在关闭一个文件的时候, 或者关闭一个服务器连接的时候。

统一try/except/finally语句

在python2.5以前,try语句有两种形式,而且是独立的两种语句,finally无法和except和else混合,但是在2.5后的版本,这两个语句可以进行合并了,他们的形式如下:

合并try的例子

这里将通过一个聚合的例子来看一下前面说过的东西,代码如下:

sep = '-'* 32 +'\n'
print(sep + 'Exception raised and caught')
try:
x = 'spam'[20]
except IndexError:
print('except run')
finally:
print('finally run')
print('after run') print(sep + 'No Exception rasied')
try:
x = 'spam'[2]
except IndexError:
print('except run')
finally:
print('finally run')
print('after run') print(sep+'No Exception raised with else')
try:
x = 'spam'[2]
except IndexError:
print('except run')
else:
print('else run')
finally:
print('finally run')
print('after run') print(sep + 'Exception rasied but not caught')
try:
x = 1 / 0
except IndexError:
print('except run')
finally:
print('finally run')
print('after run')

运行结果如下:

--------------------------------
Exception raised and caught
except run
finally run
after run
--------------------------------
No Exception rasied
finally run
after run
--------------------------------
No Exception raised with else
else run
finally run
after run
--------------------------------
Exception rasied but not caught
finally run
Traceback (most recent call last):
File "D:\application\eclipse\workspace\yichang\c2\test1.py", line 38, in <module>
x = 1 / 0
ZeroDivisionError: division by zero

raise语句

raise语句通常有三种形式

raise <instance>  #raise 一个类的实例
raise <class> #生成并且raise一个类的实例
raise #raise最近生成的异常

raise总是引发一个类的实例,所以第一种方法是最常用的,在使用第二种方法的时候,调用了类的无参构造方法来生成类的一个实例,不加任何参数的raise产生最近生成的一个异常。

except name as X: 子句的作用:变量X将会分配给引发中所提供的实例,我们看下面的一个例子:

class MyExcp(Exception):
pass
try:
raise MyExcp('nihao')
except MyExcp as X:
print(X.args)

上面的例子当中,定义了我们自己的异常,在raise的时候,传入了参数'nihao',然后在捕获的时候捕获这个对象,输出这个对象的参数,最后的结果是:

('nihao',)

空的raise语句作用,它重新引发当前异常,运行如下代码:

try:
1/0
except Exception as E:
print('nihao')
raise

得到结果:

nihao
Traceback (most recent call last):
File "D:\application\eclipse\workspace\yichang\c2\bb.py", line 2, in <module>
1/0
ZeroDivisionError: division by zero

这个时候异常会继续上抛,如果没有raise,那么程序将在try后继续执行。

assert语句

assert可以看做是带有条件的raise语句,assert的一般语法是 assert <test>,<data>  当test的部分为错误(False)的时候,触发异常。

assert的一个作用是用来收集用户自定义的约束条件,因为python会自动帮我们收集程序当中出现的错误。

比如,当x ≥0的时候,触发一个错误,x ≥0 是我们自己定义的约束,运行如下代码:

def fun(x):
assert x < 0,'x must be negative'
return x ** 2
fun(3)

输出结果如下:

Traceback (most recent call last):
File "D:\application\eclipse\workspace\yichang\c2\bb.py", line 4, in <module>
fun(3)
File "D:\application\eclipse\workspace\yichang\c2\bb.py", line 2, in fun
assert x < 0,'x must be negative'
AssertionError: x must be negative

所以assert可以在我们检查我们程序定义的约束的时候起到很大的作用。

with/as环境管理器

with语句的基本格式如下:

with expection [as variable]:
with-block

如果有as variable的话,那么会接收内部__enter__返回出来参数。要实现环境管理器,使用with 方法,那么对象里面必须有__enter__和__exit__方法的。

我们来编写一个这样的类:

class TraceBlock:
def message(self):
print('message excute')
def __enter__(self):
print('enter excuete')
return self
def __exit__(self,type,value,tb):
if type is None:
print('exit normally\n')
else:
print('raise a excpetion')
#print('type:',type,'\nvalue:',value,'\ntb:',tb)
with TraceBlock() as t:
t.message()
print('not error')
with TraceBlock() as t:
t.message()
raise TypeError
print('error')

运行结果如下:

enter excuete
message excute
not error
exit normally enter excuete
message excute
raise a excpetion
Traceback (most recent call last):
File "D:\application\eclipse\workspace\yichang\c2\bb.py", line 18, in <module>
raise TypeError
TypeError

其实我们关系的是发生异常的时候,程序是怎么运行的,我们修改上面的代码

class TraceBlock:
def __enter__(self):
return self
def __exit__(self,type,value,tb):
print('type:',type,'\nvalue:',value,'\ntb:',tb)
with TraceBlock() :
1/0

输出的结果如下:

type: <class 'ZeroDivisionError'>
value: division by zero
tb: <traceback object at 0x022ADE18>
Traceback (most recent call last):
File "D:\application\eclipse\workspace\yichang\c2\bb.py", line 8, in <module>
1/0
ZeroDivisionError: division by zero

说明,发生异常的时候,异常的参数会传入__exit__里面,在里面进行处理。


总结:

这一章讲了一些 try语句的细节,还有raise语句,assert语句以及with语句的细节。

《pyhton学习手册》 第33章 异常编码细节的更多相关文章

  1. [core java学习笔记][第十一章异常断言日志调试]

    第11章 异常,断言,日志,调试 处理错误 捕获异常 使用异常机制的技巧 使用断言 日志 测试技巧 GUI程序排错技巧 使用调试器 11.1 处理错误 11.1.1异常分类 都继承自Throwable ...

  2. 【马克-to-win】学习笔记—— 第五章 异常Exception

    第五章 异常Exception [学习笔记] [参考:JDK中文(类 Exception)] java.lang.Object java.lang.Throwable java.lang.Except ...

  3. 【译】x86程序员手册31- 第9章 异常和中断

    Chapter 9 Exceptions and Interrupts 第9章 异常和中断 Interrupts and exceptions are special kinds of control ...

  4. Python《学习手册:第二章-习题》

    什么是Python解释器? Python解释器是运行Python程序的程序. 什么是源代码? 源代码是为程序所写的语句:它包括文本文件(通常以.py为文件名结尾)的文件. 什么是字节码? 字节码是Py ...

  5. Python《学习手册:第一章-习题》

    人们选择Python的六大主要原因是什么? 软件质量:Python注重可读性.一致性和软件质量. Python代码的设计致力于可读性,因此具备了比传统脚本语言更优秀的可重用性和可维护性. Python ...

  6. Python学习手册(第4版) - 专业程序员的养成完整版PDF免费下载_百度云盘

    Python学习手册(第4版) - 专业程序员的养成完整版PDF免费下载_百度云盘 提取码:g7v1 作者简介 作为全球Python培训界的领军人物,<Python学习手册:第4版>作者M ...

  7. Python学习手册(第4版)PDF高清完整版免费下载|百度云盘

    Python学习手册(第4版)PDF高清完整版免费下载|百度云盘 提取码:z6il 内容简介 Google和YouTube由于Python的高可适应性.易于维护以及适合于快速开发而采用它.如果你想要编 ...

  8. 《Python学习手册 第五版》 -第14章 迭代和推导

    承接上一章for循环的讲解,迭代和推导,是对for循环的一种深入的探索和扩展 本章重点内容 1.迭代 1)什么是迭代?都有哪些分类 2)常规的使用方法 3)多遍迭代器VS单遍迭代器 2.列表推导 1) ...

  9. 《深入Java虚拟机学习笔记》- 第17章 异常

    <深入Java虚拟机学习笔记>- 第17章 异常

随机推荐

  1. JS几个常用的工具函数

    一个项目中JS也不可避免会出现重用,所以可以像Java一样抽成工具类,下面总结了几个常用的函数: 1.日期处理函数 将日期返回按指定格式处理过的字符串: function Format(now,mas ...

  2. django框架<二>

    django框架:   Models 1.基本创建 Django提供了一个抽象层("Model")的构建和管理Web应用程序的数据. Django使用一种新的方式,即:关系对象映射 ...

  3. 使用linux下的C操作SQLLITE

    from: http://baike.so.com/doc/1529694.html 由于Linux下侧重使用命令,没有win的操作容易上手,所以在测试C操作SQLITE时会比较容易出现错误,给大家做 ...

  4. 一个python爬虫工具类

    写了一个爬虫工具类. # -*- coding: utf-8 -*- # @Time : 2018/8/7 16:29 # @Author : cxa # @File : utils.py # @So ...

  5. java中String的==和equals的区别

    首先看代码1: public static void main(String[] args) { List<String> list=new ArrayList<String> ...

  6. [How to] HBase的bulkload使用方法

    1.简介 将数据插入HBase表中的方法很多,我们可以通过TableOutputFormat以Mapreduce on HBase的方式将数据插入,也可以单纯的使用客户端API将数据插入.但是以上方法 ...

  7. sshpass-免交互SSH登录工具

    sshpass用于自动向命令行提供密码,适用于ssh,scp,rsync,pssh,pscp等ssh系列的命令和工具 #安装sshpass yum install sshpass -y #注:当第一次 ...

  8. LeetCode765. Couples Holding Hands

    N couples sit in 2N seats arranged in a row and want to hold hands. We want to know the minimum numb ...

  9. 邂逅Sass和Compass之Compass篇

    本文主要讲解Compass的内容,众所周知Compass是Sass的工具库,如果对Sass不甚了解的同学可以移步 邂逅Sass和Compass之Sass篇 Sass本身只是一个“CSS预处理器”,Co ...

  10. eclipse 创建 maven 项目时如何修改 web 的版本和 jdk 的版本

    eclipse 创建 maven 项目时如何修改 web 的版本和 jdk 的版本 在使用 eclipse 创建 maven 项目的时候,默认的 web.xml 的版本时 2.3,默认 jre 的版本 ...