python断言异常类名_Python 断言和异常

Python 断言和异常

Python断言

断言是一种理智检查,当程序的测试完成,能够将其打开或关闭。断言的最简单方法就是把它比做raise-if语句(或更加准确,raise-if-not声明)。一个表达式进行测试,若是结果出现false,将引起异常。程序中经常放置断言来检查输入的有效与否,或在一个函数调用后检查有效的输出,其为assert关键字构成的语句。 assert语句 但它遇到一个断言语句,Python评估计算以后的表达式,但愿是true。若是是表达式为false,Python触发AssertionError异常,其语法是:python

assert Expression[, Arguments]

若是断言失败,Python使用ArgumentExpression做为AssetionError异常的参数,AssertionError能够被捕获,并用try-except语句处理,相似其余异常。可是若是没有处理它们,将终止改为程序并产生一个回溯。以下实例:函数

def kelvin_to_fahrenheit(temperature):

assert temperature >= 0, "Colder than absolute zero!"

return ((temperature-273)*1.8)+32

print(kelvin_to_fahrenheit(273))

print(kelvin_to_fahrenheit(505.78))

print(kelvin_to_fahrenheit(-5))

运行输出结果为:测试

32.0

451.00399999999996

Traceback (most recent call last):

File "D:/PythonCode/basic knowledge/exceptions.py", line 8, in

print(kelvin_to_fahrenheit(-5))

File "D:/PythonCode/basic knowledge/exceptions.py", line 2, in kelvin_to_fahrenheit

assert temperature >= 0, "Colder than absolute zero!"

AssertionError: Colder than absolute zero!

Python 异常处理

Python提供的标准异常以下列表:spa

异常名称

描述

Exception

全部异常的基类

StopIteration

当一个迭代器的next()方法不能指向任何对象时引起

SystemExit

由sys.exit()函数引起

StandardError

除了StopIteration异常和SystemExit,全部内置异常的基类

ArithmeticError

数值计算所发生的全部异常的基类

OverflowError

当数字类型计算超过最高限额引起

FloatingPointError

当一个浮点运算失败时触发

ZeroDivisonError

当除运算或模零在全部数值类型运算时引起

AssertionError

断言语句失败的状况下引起

AttributeError

属性引用或赋值失败的状况下引起

EOFError

当从 raw_input() 与 input() 函数输入,到达文件末尾时触发

ImportError

当一个 import 语句失败时触发

KeyboardInterrupt

当用户中断程序执行,一般是经过按 Ctrl+c 引起

LookupError

全部查找错误基类

IndexError、KeyError

当在一个序列中没有找到一个索引时引起;当指定的键没有在字典中找到引起

NameError

当在局部或全局命名空间中找不到的标识引起

UnboundLocalError

试图访问在函数或方法的局部变量时引起,但没有值分配给它

EnvironmentError

Python环境以外发生的全部异常的基类。

IOError

当一个输入/输出操做失败,如打印语句或 open()函数试图打开不存在的文件时引起;操做系统相关的错误时引起

SyntaxError、IndentationError

当在Python语法错误引起;没有正确指定缩进引起

SystemError、SystemExit

当解释器发现一个内部问题,但遇到此错误时,Python解释器不退出引起;当Python解释器不使用sys.exit()函数引起。若是代码没有被处理,解释器会退出

ValueError

在内置函数对于数据类型,参数的有效类型时引起,可是参数指定了无效值

RuntimeError

当生成的错误不属于任何类别时引起

NotImplementedError

当要在继承的类来实现,抽象方法实际上没有实现时引起此异常

什么是异常 异常是一个事件,在程序的执行过程当中扰乱程序的正常流程。通常来讲,当Python程序遇到某种状况,它没法应付则会引起一个异常。操作系统

异常处理 咱们可使用try/except语句来捕捉异常,try/except语句用来检测try语句块中的异常,从而让except语句捕获异常信息并处理。若是咱们不想在异常发生时程序结束,只须要在except里捕获它,其语法格式以下:code

try:

except :

except , :

else:

try的工做原理,当开始一个try语句后,Python就在当前程序的上下文中作标记,这样当异常出现时,就能够回到这里,try子句先执行,接下来会发生什么依赖于执行时是否出现异常。对象

若是try后的语句执行时发生异常,Python就跳回到try并执行第一个匹配该异常的except子句,异常处理完毕,控制流就经过整个try语句(除非在处理异常时又引起新的异常);

若是try后的语句里发生了异常,却没有匹配的except子句,异常将被递交到上层的try,或者到程序的最上层(这样将结束程序,并打印缺省的出错信息);

若是try子句执行时没有发生异常,Python将执行else语句后的语句(若是有else的话),而后控制流经过整个try语句;

如下实例,打开文件,在该文件中写入内容,并未发生异常:继承

try:

fh = open("testfile.txt", "w", encoding="utf-8")

fh.write("这是一个测试文件,用于测试异常!")

except IOError:

print("Error:没有找到文件或读取文件失败!")

else:

print("内容写入文件成功!")

fh.close()

运行输出结果为:索引

内容写入文件成功!

# 查看文件内容

这是一个测试文件,用于测试异常!

如下实例,打开文件,在该文件中写入内容,但文件没有写入权限,发生了异常(Linux环境下):事件

try:

fh = open("testfile", "w")

fh.write("这是一个测试文件,用于测试异常!!")

except IOError:

print("Error: 没有找到文件或读取文件失败")

else:

print("内容写入文件成功")

fh.close()

在执行代码前为了测试方便,咱们能够先去掉testfile.txt文件的写权限,命令以下:

chmod -w testfile.txt

在运行上面代码输出结果为:

Error: 没有找到文件或读取文件失败

使用except而不带任何异常类型 咱们能够不带任何异常类型使用except,语法以下:

try

正常的操做

.................

except:

发生异常,执行这部分代码

.................

else:

若是没有异常执行这部分代码

以上方式try-except语句捕获全部发生的异常,可是这不是一个好的方式,咱们没法经过该程序识别出具体的异常信息,由于它捕获全部的异常。

使用except而带多种异常类型 咱们可使用相同的except语句来处理多个异常信息,以下所示:

try:

正常的操做

......................

except(Exception1[, Exception2[,...ExceptionN]]]):

发生以上多个异常中的一个,执行这块代码

......................

else:

若是没有异常执行这块代码

try-finally语句 try-finally语句不管是否发生异常都将执行finally后的代码:

try:

finally:

#退出try时总会执行

raise

以下实例:

try:

fh = open("testfile", "w")

fh.write("这是一个测试文件,用于测试异常!!")

finally:

print("Error: 没有找到文件或读取文件失败")

若是打开的文件没有可写权限,输出结果以下:

Error: 没有找到文件或读取文件失败

上面实例,也能够写成以下的方式:

try:

fh = open("testfile", "w")

try:

fh.write("这是一个测试文件,用于测试异常!!")

finally:

print("关闭文件")

fh.close()

except IOError:

print("Error: 没有找到文件或读取文件失败")

当在try块中抛出一个异常,当即执行finally代码块。finally块中的全部语句执行后,异常被再次触发,并执行except代码块。

异常的参数 一个异常能够带上参数,能够做为输出的异常信息参数,咱们能够经过except语句来捕获异常的参数,以下所示:

try:

正常的操做

......................

except ExceptionType, Argument:

你能够在这输出 Argument 的值...

变量接受的异常值一般包含在异常的语句中。在元组的表单中变量能够接收一个或多个值。元组一般包含错误字符串,错误数字,错误位置。 如下为单个异常的实例:

def temp_convert(var):

try:

return int(var)

except ValueError as argument: #Python3

print("参数没有包含数字\n", argument)

temp_convert("abc")

运行输出结果为:

参数没有包含数字

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

触发异常 咱们可使用raise语句本身触发异常,其语法格式以下:

raise [Exception [, args [, traceback]]]

语句中Exception是异常的类型(例如:NameError)参数标准异常中任一种,args是本身提供的异常参数。最后一个参数是可选的(实际中不多用),若是存在,是跟踪异常对象。

实例:一个异常能够是字符串,类或对象。Python提供的内置异常,大多数都是实例化的类,这是一个类的的实例的参数,异常的定义很是简单,以下所示:

def function_name(level):

if level < 1:

raise Exception("Invalid level!", level)

# 触发异常,后面的代码就不会再执行

**注意:**为了可以捕获异常,except语句必须用相同的异常来抛出类对象或字符串,例如:咱们捕获上面异常,except语句以下所示:

try:

正常逻辑

except Exception as err:

触发自定义异常

else:

其他代码

以下实例:

def function_name(level):

if level < 1:

raise Exception("Invalid level!", level)

# 触发异常,后面的代码就不会再执行

try:

function_name(0)

except Exception as err:

print(1, err)

else:

print(2)

运行输出结果为:

1 ('Invalid level!', 0)

用户自定义异常 经过建立一个新的异常类,程序能够命名它们本身的异常。异常应该是典型的继承自Exception类,经过直接或间接的方式。如下为与RuntimeError相关的实例,实例中建立了一个类,基类为RuntimeError,用于在异常触发时输出更多的信息,在try语句块中,用户自定义的异常后执行except块语句,变量e用于建立NetworkError类的实例:

class NetworkError(RuntimeError):

def __init__(self, arg):

self.args = arg

在定义以上类后,咱们能够触发该异常,以下所示:

try:

raise NetworkError("Bad hostname")

except NetworkError as e:

print(e.args)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值