以写代学:python 错误、异常、断言

2020-01-15 11:05:16 浏览数 (3)

1.错误

(1)语法错误

     语法错误指示软件的结构上有错误,导致不能被解释器解释或编译器无法编译。这些错误必须在程序执行前纠正。

(2)逻辑错误

     逻辑错误可能是由于不完整或是不合法的输入所致。还可能是逻辑无法生成,计算,或是输出结果需要的过程无法执行

2.异常

(1)当python检测到一个错误时,解释器就会指出当前流已经无法继续执行下去,这时候就出现了异常

(2)异常是因为程序出现了错误而在正常控制流以外采取的行为。这个行为又分为两个阶段首先是引起异常发生的错误,然后是检测(和采取可能的措施)阶段

异常

描述

NameError

未声明/初始化对象

IndexError

序列中没有此索引

SyntaxError

语法错误

KeyboardInterrupt

用户中断执行

EOFError

没有内键输入,到达EOF标记

IOError

输入/输出操作失败

3.异常处理

3.1 try-except

     把你认为有可能发生异常的语句放到try里边去执行,想要捕获什么异常,就把异常放到except里边去,捕获后的异常怎么去处理,把处理的语句写到except下边,包含finally语句,except语句,try语句,else语句,with语句,实例如下。

代码语言:javascript复制
#!/usr/bin/env python

import time
import sys

for i in range(1,11):
    sys.stdout.write("r%s" % i)
    sys.stdout.flush()
    try:
        time.sleep(1)
    except KeyboardInterrupt:
        pass

     也可以有多个expect语句,无论是CTRL C或者CTRL D还是直接回车或者输入不是整数的都会有相关提示,示例1是给用户看的,会输出相应的提示信息。示例2是给程序员看的,会输出出提示信息外还有程序报错信息也一并输出。实例3可以捕获所有异常,然后统一输出某一句指定的话。

代码语言:javascript复制
示例一:
#!/usr/bin/env python

try:
    num = int(raw_input("Number: "))
except ValueError:
    print "Error: you must input a number"
except (KeyboardInterrupt, EOFError):    //如果同时捕获多个异常,需加圆括号,否则会
    print "User cancelled          认为是保存错误原因的变量
示例二:    
#!/usr/bin/env python

try:
    num = int(raw_input("Number: "))
except ValueError, reason:            //,号右边的变量(自己定义)是保存错误原因
    print "Error: you must input a number",reason  
except (KeyboardInterrupt, EOFError): 
    print "User cancelled
示例三:
#!/usr/bin/env python

try:
    num = 100 / int(raw_input("Number: "))
except:                //except后边加:表示捕获所有异常,但是不推荐这种写法
    print "something wrong     因为不知道究竟是什么报错

3.2 else语句&&finally语句

      实例4算是一个比较完整的捕获异常和没有异常之后程序怎么执行的例子,没有异常就使用else语句执行,最后的finally语句,不管异常不异常都会执行,可以用在文件打开后发生异常导致文件没有关闭,可能会发生数据损坏,使用finally可以保证文件总是能正常的关闭。

代码语言:javascript复制
示例四:
#!/usr/bin/env python

try:
    num = 100 / int(raw_input("Number: "))     
except (ValueError, ZeroDivisionError),e     //不同的异常,输出不同的信息,并且保存报错信息
    print "Error:", e
except (KeyboardInterrupt, EOFError):        //两种退出,都友好提示退出
    print "exit."
else:                                        //如果没有异常,则正常输出num
    print num
finally:                                     //不管异常是否发生,都会执行此语句
    print done

3.3 with语句

with语句是用来简化代码的,在将打开文件的操作放在with语句中,代码块结束后,文件将自动关闭

代码语言:javascript复制
>>> with open("try.py") as f:
...     data = f.readlines()
...
>>> with open("/etc/passwd") as f:
...     for line in f:
...         print line,

4.触发异常

(1)要想引发异常,最简单的形式就是输入关键字raise,后面跟要引发的异常的名称

(2)执行raise语句时,Python会创建指定的异常类的一个对象

(3)raise语句还可指定对异常对象进行初始化的参数

代码语言:javascript复制
#!/usr/bin/env python

for i in range(100):
    if i > 10:
        raise ValueError, "diaosi"
    print i,
[root@pythion python]# python raise1.py         //执行程序是如下效果
0 1 2 3 4 5 6 7 8 9 10
Traceback (most recent call last):
  File "raise1.py", line 5, in <module>
    raise ValueError, "diaosi"
ValueError: diaosi

5.断言

(1)断言是一句必须等价于布尔值为真的判定

(2)此外,发生异常也意味着表达式为假

代码语言:javascript复制
>>> assert 7 > 3, "wrong"              //为真,则没有输出
>>> assert 7 < 3, "wrong"              //为假,则输出,号后边的语句
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AssertionError: wrong

6.脚本实例

代码语言:javascript复制
#!/usr/bin/env python

import random
import operator

ops = {" ": operator.add, "-": operator.sub}

def probe():
    nums = [random.randint(1,50) for i in range(2)]
    nums.sort(reverse=True)
    op = random.choice(" -")
    answer = ops[op](*nums)
    prompt = "%s%s%s = " % (nums[0], op, nums[1])
    tries = 0
    while tries < 3:
        result = int(raw_input(prompt))
        if answer == result:
            print "very good"
            break
        else:
            print "wrong answer."
            tries  = 1
    else:
        print "%s%s" % (prompt, answer)


def main():
    while True:
        probe()
        try:
            goon = raw_input("Next one(y/n)?").strip()[0]
        except IndexError:
            continue
        except (KeyboardInterrupt, EOFError):
            goon = "n"

        if goon in "nN":
            break

if __name__ == "__main__":
    main()

0 人点赞