一.异常处理

  异常是错误发生的信号,一旦程序出错就会产生一个异常,如果该异常没有被应用程序处理,那么该异常就会跑出来,程序的执行也随之终止,也就是说异常就是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行,一般情况下,在python无法正常处理程序时就会发生的一个异常,异常也是python对象.

  异常包含三个部分:

    1.traceback异常的追钟信息

    2.异常的类型

    3.异常的信息

  错误分为两大类:

    1.语法上的错误:在程序运行前就应该立即修正

    2.逻辑上的错误

  异常处理是为了避免程序因为异常而奔溃,所以在应用程序中应该对异常进行处理,从而增强程序的健壮性

  简单的异常处理代码:

try:
代码1
代码2
代码3
......
except NameError:
当抛出的异常是NameError时执行的子代码块
except Exception:
pass
else:
pass
finally:
pass

  python标准异常

BaseException    所有异常的基类
SystemExit 解释器请求退出
KeyboardInterrupt 用户中断执行(通常是输入^C)
Exception 常规错误的基类
StopIteration 迭代器没有更多的值
GeneratorExit 生成器(generator)发生异常来通知退出
StandardError 所有的内建标准异常的基类
ArithmeticError 所有数值计算错误的基类
FloatingPointError 浮点计算错误
OverflowError 数值运算超出最大限制
ZeroDivisionError 除(或取模)零 (所有数据类型)
AssertionError 断言语句失败
AttributeError 对象没有这个属性
EOFError 没有内建输入,到达EOF 标记
EnvironmentError 操作系统错误的基类
IOError 输入/输出操作失败
OSError 操作系统错误
WindowsError 系统调用失败
ImportError 导入模块/对象失败
LookupError 无效数据查询的基类
IndexError 序列中没有此索引(index)
KeyError 映射中没有这个键
MemoryError 内存溢出错误(对于Python 解释器不是致命的)
NameError 未声明/初始化对象 (没有属性)
UnboundLocalError 访问未初始化的本地变量
ReferenceError 弱引用(Weak reference)试图访问已经垃圾回收了的对象
RuntimeError 一般的运行时错误
NotImplementedError 尚未实现的方法
SyntaxError Python 语法错误
IndentationError 缩进错误
TabError Tab 和空格混用
SystemError 一般的解释器系统错误
TypeError 对类型无效的操作
ValueError 传入无效的参数
UnicodeError Unicode 相关的错误
UnicodeDecodeError Unicode 解码时的错误
UnicodeEncodeError Unicode 编码时错误
UnicodeTranslateError Unicode 转换时错误
Warning 警告的基类
DeprecationWarning 关于被弃用的特征的警告
FutureWarning 关于构造将来语义会有改变的警告
OverflowWarning 旧的关于自动提升为长整型(long)的警告
PendingDeprecationWarning 关于特性将会被废弃的警告
RuntimeWarning 可疑的运行时行为(runtime behavior)的警告
SyntaxWarning 可疑的语法的警告
UserWarning 用户代码生成的警告

标准异常

  try...except简单案例

try:
k = {'a': 1, 'b': 2}
print(k['x'])
l1 = [1,2,3]
l1[100]
except IndexError as e:
print(123,e)

  异常处理的多分支

try:
k = {'a': 1, 'b': 2}
# print(k['x'])
l1 = [1,2,3]
l1[100]
except IndexError as e:
print('IndexError',e)
except KeyError as e:
print('KeyError',e)

  万能异常Exception:可以匹配任意类型的异常

try:
k = {'a': 1, 'b': 2}
print(k['x'])
l1 = [1,2,3]
l1[100]
except Exception as e:
print(e)

  try...else...结构

try:
k = {'a': 1, 'b': 2}
print(k['x'])
l1 = [1,2,3]
l1[100]
except Exception as e:
print(e)
else:
print('else必须放到后面,else的子代码会在被检测的代码块没有异常的情况下执行')

  try...finally..结构

try:
k = {'a': 1, 'b': 2}
print(k['x'])
l1 = [1,2,3]
l1[100]
except Exception as e:
print(e)
else:
print('else必须放到后面,else的子代码会在被检测的代码块没有异常的情况下执行')
finally:
print('无论被检测的代码有没有异常都会执行')

  主动触发异常与自定义异常

# 主动触发异常
raise TypeError("类型错误")
#
# 自定义异常类型
class MyException(BaseException):
def __init__(self,msg):
super().__init__()
self.msg = msg
def __str__(self):
return '%s'%self.msg

二.元类

  在python中,一切皆对象,而对象都是由类实例化得到的,所以通俗的说类也是一个对象,而类就是元类的实例化

class OldboyTeacher:
def __init__(self,name,age,sex):
self.name = name
self.age = age
self.sex =sex def score(self):
print('打分')
tea1 = OldboyTeacher('Yven',19,'male')
print(type(OldboyTeacher))# class 'type'>得到元类type
# tea1一定是调用OldboyTeacher得到的,如果一切皆对象那么OldboyTeacher也是一个对象,
# 只要是对象都是调用一个类实例化得到的,即OldboyTeacher = 元类(...),内置的元类是type

  所以元类,类与对象的关系为:

    1.调用元类----->自定义的类

    2.调用自定义的类----->自定义类的对象

  从而分析class关键字创建自定义类的底层工作原理,分为四步:

    1.先拿到类名

    2.再拿到类的父类们

    3.然后拿到类发名称空间(执行类体代码,将产生的名字放到类的名称空间也就是一个字典中)

    4.调用元类实例化得到自定义的类

  自定义元类来控制类的产生:

class Mymeta(type):#但凡继承了type的类才能称为自定义的元类,否则就是一个普通的类
def __init__(self,class_name,class_bases,class_dic):
# super().__init__()
print(self)
print(class_name)
print(class_bases)
print(class_dic) class OldboyTeacher(object,metaclass=Mymeta):#OldboyTeacher = Mymeta('OldboyTeacher',(Object,),{...})
school = 'oldboy'
def __init__(self,name,age,sex):
self.name = name
self.age = age
self.sex =sex def score(self):
print('打分')

模板

  自定义元类来控制类调用的过程:

class Mymeta(type):
def __call__(self, *args, **kwargs):
# self = OldboyTeacher
# args = ('Yven', 15, 'male')
# kwargs = {}
# 实例化
# 1.先产生一个空对象
obj = self.__new__(self)#obj是OldboyTeacher这个类的对象
# 2.执行__init__完成.对象的初始化属性操作
self.__init__(obj,*args,**kwargs)
# 3.返回初始化好的那个对象
return obj class OldboyTeacher(object,metaclass=Mymeta):#OldboyTeacher = Mymeta('OldboyTeacher',(Object,),{...})
school = 'oldboy'
def __init__(self,name,age,sex):
self.name = name
self.age = age
self.sex =sex def score(self):
print('打分') tea1 = OldboyTeacher('Yven',15,'male')#会触发OldboyTeacher的类(即元类)中的__call__函数
print(tea1.__dict__)

模板

 

Python异常处理及元类的更多相关文章

  1. python基础——使用元类

    python基础——使用元类 type() 动态语言和静态语言最大的不同,就是函数和类的定义,不是编译时定义的,而是运行时动态创建的. 比方说我们要定义一个Hello的class,就写一个hello. ...

  2. Python基础:元类

    一.概述 二.经典阐述 三.核心总结 1.类的创建过程 2.元类的使用惯例 四.简单案例 1.默认行为 2.使用元类 五.实践为王 一.概述 Python虽然是多范式的编程语言,但它的数据模型却是 纯 ...

  3. Python中的元类(metaclass)

    推荐+收藏:深刻理解Python中的元类(metaclass) 做一些笔记学习学习: 在大多数编程语言中,类就是用来描述如何生成一个对象的代码段,在Python中类也是一个对象,这个(类)对象自身拥有 ...

  4. [转]深刻理解Python中的元类(metaclass)以及元类实现单例模式

    使用元类 深刻理解Python中的元类(metaclass)以及元类实现单例模式 在看一些框架源代码的过程中碰到很多元类的实例,看起来很吃力很晦涩:在看python cookbook中关于元类创建单例 ...

  5. 什么是python中的元类

    所属网站分类: python高级 > 面向对象 作者:goodbody 原文链接: http://www.pythonheidong.com/blog/article/11/ 来源:python ...

  6. Python之面向对象元类

    Python之面向对象元类 call方法: class People: def __init__(self,name): self.name=name # def __call__(self, *ar ...

  7. [Python之路] 元类(引申 单例模式)

    一.类也是对象 当我们定义一个变量或者函数的时候,我们可以在globals()的返回值字典中找到响应的映射: def A(): print("This is function A" ...

  8. Python 中的元类到底是什么?这篇恐怕是最清楚的了

    类作为对象 在理解元类之前,您需要掌握 Python 的类.Python 从 Smalltalk 语言中借用了一个非常特殊的类概念. 在大多数语言中,类只是描述如何产生对象的代码段.在 Python ...

  9. Python面向对象06 /元类type、反射、函数与类的区别、特殊的双下方法

    Python面向对象06 /元类type.反射.函数与类的区别.特殊的双下方法 目录 Python面向对象06 /元类type.反射.函数与类的区别.特殊的双下方法 1. 元类type 2. 反射 3 ...

随机推荐

  1. 视图view没有主键,但可以添加唯一索引

    视图没有主键,但可以加上唯一索引 大致可以这样理解:视图是张虚拟的表.视图所对应的数据不进行实际的存储,数据库中只存储视图的定义,对视图的数据进行操作时,系统根据视图的定义去操作与视图相关联的基本表. ...

  2. 剑指offer —— 从尾到头打印链表

    1.问题:输入一个链表,从尾到头打印链表每个节点的值. /** * public class ListNode { * int val; * ListNode next = null; * * Lis ...

  3. P2381 圆圆舞蹈

    题意:一个圆,上面有n头牛(卧槽) 给出相邻两头牛顺时针的距离 问两只最远的牛的距离(min(顺时针距离,逆时针距离)) 最远距离一定$\le$距离和/2 先求个前缀和 那么问题转化为:找到 $s_j ...

  4. Luogu1829 JZPTAB

    JZPTAB 求\(\sum_{i=1}^n\sum_{j=1}^mlcm(i,j)\) \(=\sum_{i=1}^n\sum_{j=1}^m\frac{ij}{\gcd(i,j)}\) 枚举gcd ...

  5. Arcgis Server for JavaScript API之自定义InfoWindow

    各位看到这个标题不要嫌烦,因为本人最近一直在研究相关的问题,所以相关文章也只能是这些,同时希望看过我的文章的朋友,我的文章能够给你帮助. 在前面的两篇相关的文章里面,实现InfoWindow是通过di ...

  6. anglarJs前端控制器的继承

    继承就是将相关内容进行抽离,将公共部分进行分离,然后被其他模块继承就可以实现多用 例如抽离分页部分: //品牌控制层 app.controller('baseController' ,function ...

  7. IO流图

    1.InputStream类是字节输入流的抽象类,是所有字节输入流的父类,InputStream类具有层次结构如下图所示: 2.Reader类是字符输入流的抽象类,所有字符输入流的实现都是它的子类. ...

  8. 读经典——《CLR via C#》(Jeffrey Richter著) 笔记_发布者策略控制

    在 读经典——<CLR via C#>(Jeffrey Richter著) 笔记_高级管理控制(配置)中,是由程序集的发布者将程序集的一个新版本发送给管理员,后者安装程序集,并手动编辑应用 ...

  9. Lintcode 摊平嵌套的列表

    /** * // This is the interface that allows for creating nested lists. * // You should not implement ...

  10. mysql初始化

    注意:--install前,必须用mysql启动命令的绝对路径 # 制作MySQL的Windows服务,在终端执行此命令: mysqld --install # 移除MySQL的Windows服务,在 ...