zoukankan      html  css  js  c++  java
  • 异常处理

    #异常处理
    #异常:程序运行时发生错误的信号(异常的追踪信息、异常类、异常值)
    #python中的异常种类:在python中不同的异常可以用不同的类型(python中统一类类与类型)去标识,不同的类对象标识不同的异常,一个异常标识一种错误
    
    #常用异常
    AttributeError  #试图访问一个对象没有的树形,比如foo.x,但是foo没有属性x
    IOError #输入/输出异常;基本上是无法打开文件
    ImportError #无法引入模块或包;基本上是路径问题或名称错误
    IndentationError  #语法错误(的子类);代码没有正确对齐
    IndexError   #下标索引超出序列边界,比如当x只有三个元素,却试图访问x[5]
    KeyError    #试图访问字典中不存在的健
    KeyboardInterrupt  #Ctrl+C被按下
    NameError  #使用一个还未被赋予对象的变量
    SyntaxError  #python代码非法,代码不能编译(个人认为是语法错误)
    TypeError  #传入对象类型与要求的不符合
    UnboundLocalError  #试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量,导致你以为正在访问它
    ValueError  #  传入一个调用者不期望的值,即使值得类型是正确的
    
    '''
    python解释器执行程序,检测到一个错误时,触发异常,在异常触发后且没被处理的情况下,程序就在当前异常处终止,后面的代码不会运行,。
    所以需要一种异常处理机制来增强程序的健壮性与容错性
    
    程序员编写特定的代码,专门用来捕捉这个异常(这段代码与程序逻辑无关)),如果捕捉成功则进入另外一个处理分支,执行你为其制定的逻辑,使程序不会崩溃,这就是异常处理。
    
    '''
    #用if判断做异常处理
    #知识点:isdigit()函数,判断一个值是否为整数,返回True或False
    # num1=input('>>: 请输入一个整数')
    # if num1.isdigit():
    #     print(int(num1))
    # elif num1.isspace():
    #     print('输入的是一个空格,就执行这里的逻辑')
    # elif len(num1) == 0:
    #     print('输入为空,就执行这里的逻辑')
    # else:
    #     print('其它情况,执行这里的逻辑')
    #总结:if判断式的异常处理只能针对某一段代码,如果要求对同一类错误要有不同的提示,则用if,如果没有要求,则用try,这样代码简洁
    
    # def test():
    #     print('test running')
    # choice_dic={'1':test}
    # while True:
    #     choice=input('>>: ').strip()
    #     if not choice or choice not in choice_dic:continue
    #     choice_dic[choice]()
    # #对与字典来说,i in dic ,i指的是key
    
    
    #try异常处理语法
    '''
    try:
        被检测的代码块
        #如果被检测的代码块中发生异常,则其下的代码不在执行,直接去except中查找有没有响应的异常类型。
    except 异常类型1:
        try中一旦检测到指定的异常类型,就执行这个位置的逻辑
    except 异常类型2:
        检测到的异常为该异常,则执行这个位置的逻辑
    except Exception:
        万能异常,相当于if  elif  elif  else结构,这些异常处理只处理一次
    else:
        这里放的是如果try中没有匹配到异常才执行这个位置的逻辑
    finally:
        不管有没有异常都会执行的逻辑,
        多用于回收资源的代码,如关闭文件等。
    '''
    
    # try:
    #     f = open('a.txt')
    #     next(f)
    #     next(f)
    #     next(f)
    #     next(f)#得到一个迭代器,如果next次数超过行数会报错
    # finally:
    #     print('finally run')
    #     f.close()
    

      

  • 相关阅读:
    linux下的shell 快捷键
    Python3.x和Python2.x的区别
    [Python2.x] 利用commands模块执行Linux shell命令
    redis缓存策略
    高并发解决方案
    java8 lambda表达式应用
    java读写分离的实现
    数据库读写分离
    大数据量处理方案:分布式数据库
    google的CacheBuilder缓存
  • 原文地址:https://www.cnblogs.com/wangkc/p/7081223.html
Copyright © 2011-2022 走看看