1、反射
以下均是对对象的操作,而不是对类
1 class Foo(object): 2 3 def __init__(self): 4 self.name = 'wupeiqi' 5 6 def func(self): 7 return 'func' 8 9 obj = Foo() 10 11 # #### 检查是否含有成员 #### 12 hasattr(obj, 'name') 13 hasattr(obj, 'func') 14 15 # #### 获取类内与名称一样的成员地址 #### 16 getattr(obj, 'name') 17 getattr(obj, 'func') 18 19 # #### 设置成员 ####把类外的方法(函数)放到类内 20 setattr(obj, 'age', 18) 21 setattr(obj, 'show', lambda num: num + 1) 22 23 # #### 删除成员 #### 24 delattr(obj, 'name') 25 delattr(obj, 'func') 26 27 反射代码示例
1 def bulk(self): 2 print("%s is yelling...." %self.name) 3 4 class Dog(object): 5 def __init__(self,name): 6 self.name = name 7 8 def eat(self,food): 9 print("%s is eating..."%self.name,food) 10 11 12 d = Dog("NiuHanYang") 13 choice = input(">>:").strip() 14 15 if hasattr(d,choice): 16 getattr(d,choice)#d.choice 17 else: 18 setattr(d,choice,bulk) #d.talk = bulk#在对象中添加了choice输入内容的方法(函数) 19 func = getattr(d, choice) 20 func(d)
2、异常处理
01. 异常的概念
- 程序在运行时,如果
Python 解释器
遇到 到一个错误,会停止程序的执行,并且提示一些错误信息,这就是 异常 - 程序停止执行并且提示错误信息 这个动作,我们通常称之为:抛出(raise)异常
程序开发时,很难将 所有的特殊情况 都处理的面面俱到,通过 异常捕获 可以针对突发事件做集中的处理,从而保证程序的 稳定性和健壮性
02. 捕获异常
2.1 简单的捕获异常语法
- 在程序开发中,如果 对某些代码的执行不能确定是否正确,可以增加
try(尝试)
来 捕获异常 - 捕获异常最简单的语法格式:
try: 尝试执行的代码 except: 出现错误的处理
try
尝试,下方编写要尝试代码,不确定是否能够正常执行的代码except
如果不是,下方编写尝试失败的代码
简单异常捕获演练 —— 要求用户输入整数
try: # 提示用户输入一个数字 num = int(input("请输入数字:")) except: print("请输入正确的数字")
2.2 错误类型捕获
-
在程序执行时,可能会遇到 不同类型的异常,并且需要 针对不同类型的异常,做出不同的响应,这个时候,就需要捕获错误类型了
-
语法如下:
try: # 尝试执行的代码 pass except 错误类型1: # 针对错误类型1,对应的代码处理 pass except (错误类型2, 错误类型3): # 针对错误类型2 和 3,对应的代码处理 pass except Exception as result: print("未知错误 %s" % result)
- 当
Python
解释器 抛出异常 时,最后一行错误信息的第一个单词,就是错误类型
异常类型捕获演练 —— 要求用户输入整数
需求
- 提示用户输入一个整数
- 使用
8
除以用户输入的整数并且输出
try: num = int(input("请输入整数:")) result = 8 / num print(result) except ValueError: print("请输入正确的整数") except ZeroDivisionError: print("除 0 错误")
捕获未知错误
- 在开发时,要预判到所有可能出现的错误,还是有一定难度的
- 如果希望程序 无论出现任何错误,都不会因为
Python
解释器 抛出异常而被终止,可以再增加一个except
语法如下:
except Exception as result: print("未知错误 %s" % result)
2.3 异常捕获完整语法
- 在实际开发中,为了能够处理复杂的异常情况,完整的异常语法如下:
try: # 尝试执行的代码 pass except 错误类型1: # 针对错误类型1,对应的代码处理 pass except 错误类型2: # 针对错误类型2,对应的代码处理 pass except (错误类型3, 错误类型4): # 针对错误类型3 和 4,对应的代码处理 pass except Exception as result: # 打印错误信息 print(result) else: # 没有异常才会执行的代码 pass finally: # 无论是否有异常,都会执行的代码 print("无论是否有异常,都会执行的代码")
else
只有在没有异常时才会执行的代码-
finally
无论是否有异常,都会执行的代码
自定义异常:
1 class WupeiqiException(Exception): 2 3 def __init__(self, msg): 4 self.message = msg 5 6 try: 7 raise WupeiqiException('我的异常')#主动触发异常 8 except WupeiqiException as e: 9 print e
03. 异常的传递
- 异常的传递 —— 当 函数/方法 执行 出现异常,会 将异常传递 给 函数/方法 的 调用一方
- 如果 传递到主程序,仍然 没有异常处理,程序才会被终止
提示
- 在开发中,可以在主函数中增加 异常捕获
- 而在主函数中调用的其他函数,只要出现异常,都会传递到主函数的 异常捕获 中
- 这样就不需要在代码中,增加大量的 异常捕获,能够保证代码的整洁
需求
- 定义函数
demo1()
提示用户输入一个整数并且返回 - 定义函数
demo2()
调用demo1()
- 在主程序中调用
demo2()
def demo1(): return int(input("请输入一个整数:")) def demo2(): return demo1() try: print(demo2()) except ValueError: print("请输入正确的整数") except Exception as result: print("未知错误 %s" % result)