第九节-异常/pycharm开发环境的调试

本文详细介绍了Python的异常处理机制,包括try...except结构及其变体,异常定位与解决,以及如何使用with上下文管理确保资源释放。同时,讲解了PyCharm的调试功能,如设置断点和进入调试视图的方式,帮助开发者提升调试效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

异常(Exception)

异常机制本质

所谓异常处理,就是指程序在出现问题时依然可以正确的执行剩余的程序,而不会因为异常而终止程序执行。
python中,引进了很多用来描述和处理异常的类,称为异常类。异常类定义包含了该类异常的信息和对异常进行处理的方法。
python中内建异常类的继承层次
python中一切都是对象,异常也采用对象的方式来处理。处理过程:
1、抛出异常:在执行一个方法时,如果发生异常,则这个方法生成代表该异常的一个对象,停止当前执行路径,并把异常对象提交给解释器
2、捕获异常:解释器得到该异常后,寻找相应的代码来处理该异常。

解决异常问题的态度
遇错不要慌,先让度娘亮亮相!
异常解决的关键:定位

try…一个except结构

try:
被监控的可能引发一场的语句块
except BaseException[as e]:
异常处理语句块

try块包含着可能引发异常的代码,except块用来捕捉和处理发生的异常。执行的时候,如果try块没有引发异常,则跳过except块继续执行后续代码;执行的时候,如果try块发生异常,则跳过try块中的后续代码,跳到相应的except中处理异常;异常处理完后,继续执行后续代码。

while True:
    try:
        x = int(input('请输入数字'))
        print('输入的数字:', x)
        if x == 88:
            print('退出程序')
            break
    except BaseException as e:
        print(e)
        print('异常,输入的不是一个数字')

print('循环数字输入程序结束')

try…多个except结构

上面的结构可以捕获所有的异常,工作中也很常见。但是,从经典理论考虑,一般建议尽量捕获可能出现的多个异常(按照先子类后父类的顺序),并且针对性的写出异常处理代码。为了避免遗漏可能出现的异常,可以在最后增加BaseException。结构如下:

try:
被监控的、可能引发异常的语句块
except Exception1:
处理Exception1的语句块
except Exception2:
处理Exception2的语句块

except BaseException:
处理可能遗漏的异常的语句块

try:
    a = input('请输入一个被除数:')
    b = input('请输入一个除数:')
    c = float(a)/float(b)
    print(c)
except ZeroDivisionError:
    print('异常')
except ValueError:
    print('异常,不能将字符串转化为数字')
except NameError:
    print('异常,变量不存在')
except BaseException as e:
    print(e)

try…except…else结构

ry…except…else结构增加了“else块”。如果try块中没有抛出异常,则执行else块。如果try块中抛出异常,则执行except块,不执行else块。

try:
    a=input("请输入被除数:")
    b=input("请输入除数:")
    c=float(a)/float(b)
except BaseException as e:
    print(e)
else:
    print("除的结果是:",c)

try…except…finally结构

try…except…finally结构中,finally块无论是否发生异常都会被执行;通常用来释放try块中申请的资源。

try:
    a=input('请输入一个除数')
    b=input('请输入一个被除数')
    c = float(a)/float(b)
    
except BaseException as e:
    print(e)
else:
    print(c)
finally:
    print('我是finally中的语句,无论发生异常与否,都执行')
print('程序结束!')
try:
    f = open('d:/a.txt','r')#r为读模式
    content = f.readline()
    print(content)
except:
    print('文件未找到')
finally:
    print('run in finally.关闭资源')
    try:
        f.close()
    except BaseException as e:
        print(e)
print('程序执行结束')

return语句和异常处理问题

return有两种作用:结束方法运行,返回值
我们一般不把return放到异常处理结构中,而是放到方法最后

常见异常的解决

在这里插入图片描述
在这里插入图片描述
常见异常汇总
在这里插入图片描述
在这里插入图片描述

with上下文管理

finally块由于是否发生异常都会执行,通常我们放释放资源的代码。其实,我们可以通过with上下文管理,更方便的实现释放资源的操作
with上下文管理的语法结构如下:
with context_expr[as var]:
语句块
with上下文管理可以自动管理资源,在with代码块执行完毕后自动还原进入该代码之前的现场或上下文。不论何种原因跳出with块,不论是否有异常,总能保证资源正常释放。极大的简化了工作,在文件操作、网络通信相关的场合非常常用。
不管这个语句块有无异常,with语句块执行完毕后,在这里打开的资源就会全部释放并且关闭。

with open('d:/adddd.txt','r') as f:
    content = f.readline()
    print(content)
print('程序执行结束')

traceback模块

用来打印异常信息
因为是模块,所以直接import即可

import traceback
try:
    print('step1')
    num=1/0
except:
    with open('d:/a.txt','a') as f:
        traceback.print_exc(file=f)
#将异常信息输入到指定文件夹中

自定义异常

程序开发中,有时候我们也需要自己定义异常类。自定义异常类一般都是运行时异常,通常继承Exception或其子类即可。命名一般以Error、Exception为后缀。自定义异常由raise语句主动抛出。

class AgeError(Exception):
    def __init__(self,errorInfo):
        Exception.__init__(self)
        self.errorInfo = errorInfo
    def __str__(self):
        return str(self.errorInfo)+ ',年龄错误!应该在1-150之间'
if __name__ == "__main__":
    age = int(input('请输入一个年龄:'))
    if age<1 or age>150:
        raise AgeError(age)
    else:
        print('正常的年龄:',age)

pycharm开发环境的调试

断点
(1)在行号后面单击即可增加断点
(2)在断点上再单击即可取消断点
进入调试视图
我们通过如下三种方式都可以进入调试视图:
(1)单击工具栏上的按钮:虫图标
(2)右键单击编辑区,点击:debug‘模块名’
(3)快捷键:shift+F9
在这里插入图片描述
调试操作区
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值