Python学习计划(十一)
面向对象(三)
一、异常简介
异常,即程序出现错误。
若此时文件不存在,在执行程序是将显示如下:
Traceback (most recent call last):
File "C:\Users\萌蛋蛋灬左\Desktop\1.py", line 5, in <module>
open("a.txt")
FileNotFoundError: [Errno 2] No such file or directory: 'a.txt'
二、捕获异常
异常一旦发生,如果不加以处理,则程序中断。
如何能够提高程序的健壮性?
对于一般可预见性的异常,我们一般可以事先预防,即就是当程序出现问题时,我们有预先的处理机制。
1、try except语句:
try:print("异常发生前")
open("a.txt")
print("异常发生后")
except IOError:
print("捕捉到了异常")
- 把可能出现问题的代码放在try中
- 把处理异常的代码挡在except中
2、except也可以一次性捕捉多个异常:
try:print("异常发生前")
print(num)
open("a.txt")
print("异常发生后")
except(IOError,NameError):
print("捕捉到了异常")
3、也可用as关键字将异常信息存储:
try:print("异常发生前")
print(num)
open("a.txt")
print("异常发生后")
except(IOError,NameError) as result:
print("捕捉到了异常")
print(result)
4、也可以一次性捕捉:
try:print("异常发生前")
print(num)
open("a.txt")
print("异常发生后")
except Exception as result:
print("捕捉到了异常")
print(result)
5、else如果没发生异常则执行:
try:print("异常发生前")
#print(num)
#open("a.txt")
print("异常发生后")
except Exception as result:
print("捕捉到了异常")
print(result)
else:
print("万幸")
6、finally无论错误与否,都要执行:
try:print("异常发生前")
#print(num)
#open("a.txt")
print("异常发生后")
except Exception as result:
print("捕捉到了异常")
print(result)
finally:
print("必须执行!")
三、异常的传递
def test1():print("---test1-1---")
print(num)
print("---test1-2---")
def test2():
print("---test2-1---")
test1()
print("---test2-2---")
def test3():
try:
print("---test3-1---")
test1()
print("---test3-2---")
except Exception as result:
print("捕捉到了异常,信息是:%s"%result)
print("---test3-2---")
test3()
print("-----------华丽的分割线-----------")
test2()
- 如果一个异常是在一个函数中产生的,例如函数A—>函数B---->函数C,而异常是在函数C中产生的,那么如果函数C中没有对这个异常进行处理,那么这个异常会传递到函数B中,如果函数B有异常那么就会按照函数B的处理方式进行执行;如果 函数B也没有异常处理,那么这个异常就会继续传递,以此类推…如果所有的函数都没有处理,那么此时就会进行异常的默认处理,即通常所见。
- 当调用test3函数时,在test1函数内部产生了异常,此异常被传递到test3函数中完成了异常处理,而当异常处理完成后,并没有返回到函数test1中进行执行,而是在函数test3中继续执行
四、抛出自定义异常
可以用raise语句来引发一个异常。异常/错误对象必须有一个名字,且它们应是Error或Exception类的子类。
#自定义的异常类
def _init_(self,length,atleast):
#super()._init_()
self.length = length
self.atleast = atleast
try:
s = inpute("请输入--->")
if len(s) < 3:
#raise引发一个你定义的异常
raise ShortlnputException(len(s),3)
except ShortlnputException as result:
#x这个变量被绑定到了错误的实例
print('ShortlnputException:输入的长度是%d,长度至少应是%d'% (result.length,result.athleast))
else:
print("没有异常发生")
以上程序中,关于代码#super().init()的说明:
这一行代码,可以调用也可以不调用 ,建议调用,因为_init_方法往往是用来对创建完的对象进行初始化工作,如果在子类中重写了父类的_init_方法,即意味着父类中的很多初始化工作没有做,这样就不保证程序的稳定了,所以在以后的开发中,如果重写了父类的_init_方法,最好是先调用父类的这个方法,然后再添加自己的功能。
五、异常处理中的抛出异常
class Test(object):def _init_(self,switch):
self.switch = switch
def calc(self,a,b):
try:
return a/b
except Exception as result:
if self.switch:
print("捕获开启,已经捕获到了异常,信息如下:")
print(result)
else:
#重新抛出这个异常,此时就不会被这个异常处理给捕获到,从而触发默认的异常处理
raise
t = Test(False)
t.calc(1,0)
六、模块介绍
有过C语言编程经验的朋友都知道在C语言中如果要引用sqr函数,必须用语句#include<math.h>引入math.h这个文件,否则是无法正常机械能调用的。
那么python中,如果要引用一些其他的函数,该怎么处理?
在python中有一个概念叫做模块,这个和C语言中的开头文件以及JAVA中的包很类似,比如在python中要调用sqr函数,必须用import关键字引入math这个模块
说的通俗点就是:模块就好比是工具包,要想使用这个工具包中的工具,就需要导入这个模块
1、import:
在python中用关键字import来引入某个模块,比如要引用模块math,就可以在文件最开始的地方用import math来引入。
在调用math模块中的函数时,必须这样引用:
2、from import:
在python的from语句让你从模块中导入一个指定的部分到当前命名空间中
七、模块制作
1、定义自己的模块
在python中,每个文件都可以制作一个模块,模块的名字就是文件的名字
比如有这样一个文件test.py,在test.py中定义了函数add
def add(a,b):
return a+b
2、调用自己的模块:
那么在其他文件中就可以先import test,然后通过test.add(a,b)来调用了,当然可以通过from test import add来引入。
import test
result = test.add(11,22)
print(result)
八、给程序传参数
import sysprint(sys.argv)
九、列表推导式
所谓的列表推导式,就是指的轻量级循环创建的列表
In[3]:a
Out[3]:[0,1,2,3]
In[4]:a = [x for x in range(3,4)]
In[5]:a
Out[5]:[3]
In[6]:a = [x for x in range(3,19)]
In[7]:a
Out[7]:[3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18]
In[8]:a = [x for x in range(3,19,2)]
In[9]:a
Out[9]:[3,5,7,9,11,13,15,17]
In[10]:a = [x for x in range(3,10) if x%2 == 0 ]
In[11]:a
Out[11]:[4,6,8]
In[12]:a = [x for x in range(3,10) if x%2 != 0 ]
In[13]:a
Out[13]:[3,5,7,9]
In[14]:a = [x for x in range(3,10)]
In[15]:a
Out[15]:[3,4,5,6,7,8,9]
…
In[29]:a = [(x,y) for x in range(1,3) for y in range(3)]
In[30]:a
Out[30]:[(1,0),(1,1),(1,2),(2,0),(2,1),(2,2)]
创作者:Eric· Charles