小甲鱼Python第033讲:异常处理:你不可能总是对的2| 课后测试题及参考答案

测试题:

0.我们使用什么方法来处理程序中出现的异常?

使用try......except搭配来捕获处理程序中的出现的异常。

try:
     检测范围
 except Exception[as reason]:
     出现异常(Exception)后的处理代码

1.一个try语句可以和多个except语句搭配吗?为什么?

可以。因为try语句块中可能出现多类异常,利用多个except语句可以分别捕获并处理我们感兴趣的异常。

try:
    sum = 1+‘1‘
    f = open(‘我是一个不存在的文档.txt‘)
    print(f.read)
    f.close()
except OSError as reason:
    print("文件出错了\n错误原因是:" + str(reason))
except TypeError as reason:
    print("类型出错了\n错误原因是:" + str(reason))

2.你知道如何统一处理多类异常吗?

在except后边使用小括号()把多个需要统一处理的异常括起来:

try:
    int("abc")
    sum = 1+‘1‘
    f = open(‘我是一个不存在的文档.txt‘)
    print(f.read)
    f.close()
except (OSError,TypeError) as reason:
    print("出错了\n错误原因是:" + str(reason))

3.except后边如果不带认识异常类,python会捕获所有(try语句块内)的异常并统一处理,但是小甲鱼却不建议这么做,你知道是为什么吗?

因为它会隐藏所有程序员未想到并且未作好处理的错误,例如用户输入ctrl+c试图终止程序会被解释为KeyboardInterrupt异常。

4.如果异常发生在成功打开文件后,python跳到except语句执行,并没有执行关闭文件的命令(用户写入文件的数据就可能没有保存起来),因此我们需要确保无论如何(就算出了一场退出)文件也要被关闭,我们应该怎么做呢?

我们可以使用finally语句来实现,如果try语句块中没有出现任何运行时错误,会跳过except语句块执行finally语句块的内容。

如果出现异常,则会先执行except语句块的内容再接着执行finally语句块的内容,总之,finally语句块里的内容就是确保无论如何都将被执行的内容!

5.请恢复以下代码中马赛克挡住的内容,使用程序执行后可以按要求输出。

小甲鱼Python第033讲:异常处理:你不可能总是对的2| 课后测试题及参考答案

实现代码: 

try:
    for i in range(3):
        for j in range(3):
            if i == 2:
                raise KeyboardInterrupt
            print(i,j)
except KeyboardInterrupt:
    print("退出了!")

动动手:

0.还记得我们第一个小游戏吗?只要用户输入非整数数据,程序立刻就会蹦出来不和谐的异常信息然后崩溃,请使用刚学的异常处理方法修改一下程序,提高用户体验。

猜数字小游戏:

import random

secret = random.randint(1,10)
print("--------------------小鱼儿工作室-------------------")
temp= input("不妨猜一下小甲鱼现在心里想的是哪个数字:")
guess = int(temp)
while guess != secret:
    temp = input("哎呀,猜错了。请重新输入吧:")
    guess = int(temp)
    if guess == secret:
        print("WC,你是小甲鱼心里的蛔虫吗?!")
        print("猜中了呢!")
    else:
        if guess >secret:
            print("哥,大了大了")
        else:
            print("嘿,小了小了")
print("游戏结束,不玩了~~")

优化代码:主要在guess= int(temp)上当输入的temp不是整数型的时候,会出现异常。

import random

secret = random.randint(1,10)
print("--------------------小鱼儿工作室-------------------")
temp= input("不妨猜一下小甲鱼现在心里想的是哪个数字:")
try:
    guess = int(temp)
except ValueError:
    print("输入错误,请输入整数。")    guess = secret 
while guess != secret:
    temp = input("哎呀,猜错了。请重新输入吧:")
    guess = int(temp)
    if guess == secret:
        print("WC,你是小甲鱼心里的蛔虫吗?!")
        print("猜中了呢!")
    else:
        if guess >secret:
            print("哥,大了大了")
        else:
            print("嘿,小了小了")
print("游戏结束,不玩了~~")

1.input()函数有可能产生两类异常:EOFError(文件末尾endoffice,当用户按下组合键CTRL+d产生)和KeyboardInterrupt(取消输入,当用户按下组合键Ctrl+c产生),再次修改上边代码,捕获处理input()的两类异常,提高用户体验。

实现代码:

import random

secret = random.randint(1,10)
print("--------------------小鱼儿工作室-------------------")
try:
    temp = input("不妨猜一下小甲鱼现在心里想的是哪个数字:")
    guess = int(temp)
except (EOFError, KeyboardInterrupt, ValueError):
    print("输入错误,请输入整数。")
    guess = secret
while guess != secret:
    temp = input("哎呀,猜错了。请重新输入吧:")
    guess = int(temp)
    if guess == secret:
        print("WC,你是小甲鱼心里的蛔虫吗?!")
        print("猜中了呢!")
    else:
        if guess >secret:
            print("哥,大了大了")
        else:
            print("嘿,小了小了")
print("游戏结束,不玩了~~")

2.尝试一个新的函数int_input(),当用户输入整数的时候正常返回,否则提示出错并要求重新输入。

程序实现如图:

小甲鱼Python第033讲:异常处理:你不可能总是对的2| 课后测试题及参考答案

方法一:

def int_input(prompt):
    while True:
        try:
            int(input(prompt))
            break
        except ValueError:
            print("出错,您输入的不是整数!")

int_input("请输入一个整数:")

方法二:

def  int_input1():
    temp = input("请输入一个整数:")
    try :
        num = int(temp)
    except ValueError:
        print("出错了~~!!")
        int_input1()
int_input1()

3.把文件关闭在finally语句块中执行还是会出现问题,像下边这个代码,当前文件夹中并不存在‘My_File.txt’这个文件,那么程序执行起来会发生什么事情呢?你有办法解决这个问题吗?

try:
    f = open(‘My_File.txt‘)
    print(f.read())
except OSError as reason:
    print("出错了:"+str(reason))
finally:
f.close()

优化代码:

try:
    f = open ("My_File.txt") # 当前文件夹中并不存在“My_File.txt”这个文件
    print(f.read())
except OSError as reason:
    print("出错了:" +str(reason))
finally:
    if ‘f‘ in locals(): # 如果文件对象变量存在当前局部变量符号表的话,说明打开成功
        f.close()