python异常处理与上下文管理器

简介: 今天讲python异常处理与上下文管理器原理

python异常处理



异常与错误

  • 错误
  • 语法错误

可以通过IDE或者解释器给出提示的错误

opentxt('a.jpg','r')

  • 逻辑错误

语法层面没有问题,但是自己代码的逻辑有问题

if age>18: print('未成年')


  • 异常

多指在程序执行过程中,出现的未知错误,语法和逻辑本身是正确的。可以通过代码进行处理或修复


异常分类

  • 除零异常(ZeroDivisionError):

1/0


  • 名称异常(NameError):

if age>5,age未定义


  • 类型异常(TypeError):

1+'abc'


  • 索引异常(IndexError):

a=[1,2,3] a[4]


  • 键异常(KeyError):

a={'a':1,'b':2} a['c']


  • 值异常(ValueError)

int('abcd')


  • 属性异常(AttributeError)

name='Dracular' print(name.age)


  • 迭代器异常(StopIteration)

a=iter([1,2]) print(next(a)) print(next(a)) print(next(a))


  • 系统异常类继承树(BaseException所有内建的异常基类)
  • SystemExit


由sys.exit(0函数引发,当他不处理时,python解释器退出)

  • KeyboardInterrupt


当用户中断操作引发(ctrl +c)

  • GeneratorExit


当调用一种generator的close()方法引发

  • Exception


所有内置的、非系统退出异常是从该类派生的,因为该类派生所有用户定义的异常


异常处理格式

# python 的完整异常处理格式,原谅我蹩脚的英语注释,哈哈...
# python 2 中except exception_type, error
# python 3 中except exception_type as error
try:
    do something
except exception_type1:
    when get exception_type1 error
except exception_type2:
    when get exception_type2 error
except exception_typen:
    when get exception_type2 error
else:
    if not get error,into here
finally:
    always execute it ...


多种异常捕获

刚才介绍了很多异常的分类,也看到了异常处理的格式,那么针对多种异常如何更简洁的捕获呢?


  • 将多个异常通过元组归类到一起
    except (ZeroDivisionError,NameError) as error:
  • 使用Exception这个基类全部捕获
    except Exception as errorinfo:


使用with处理异常

用于执行一段代码前,进行预处理,执行完成这段代码后,进行清理操作

with content_expression[as target(s)]: withbody

大家用到最多的莫过于在读写文件时,使用with open

with open('a.txt','a') as file :
    file.write('first line...')


为什么说他是一个上下文处理器呢?


首先咱们在文件读写的时候主要分三个步骤:

  1. 打开文件
  2. 操作文件的内容
  3. 关闭文件


正常情况下,我们使用的方式为:

f=open('a.txt', 'a')
f.write('first line...')
f.close()

那么如果我们在操作文件的时候,出现了异常导致系统退出,就无法正常的关闭文件

但使用with的上下文管理器,就可以达到异常退出时的清理操作!


可是没有论证,空口在这里吹逼不太好啊,举个例子来验证with自带的异常清理。

先看下这段代码:

import os
try:
    f=open('a.txt', 'a+')
    f.write('first line...')
    raise ValueError
except:
    os.rename('a.txt','b.txt')
f.close()
output:
PermissionError: [WinError 32] 另一个程序正在使用此文件,进程无法访问。: 'a.txt' -> 'b.txt'

我们在写文件的时候,手动出发一个异常,然后在except捕获异常后,去重命名该文件。


然后由于没有正常的关闭,此时你去重命名会给出文件正在占用的提示

那同样的方式,我们使用with操作看看效果:

import os
try:
    with open('a.txt', 'a+') as file:
        file.write('first line...')
        raise ValueError
except:
    os.rename('a.txt','b.txt')

此时正常执行完成,程序没有抛出异常,为什么?因为在上下文处理器中,with捕获异常后,自动的执行了文件的关闭操作,溜不溜?


上下文管理器原理


所谓上下文管理器的原理,其实就是以下三点:


  1. 调用enter 方法,进行预处理操作
  2. 执行用户操作
  3. 调用exit方法,完成清理操作


知道了原理,让我们通过自己编写的上下文管理器,重构一下open的方法,让它装逼即耀眼又安全吧

import os
# 自定义一个上下文管理器
class zhuang13_open:
    def __init__(self, file, mode):
        self.file = file
        self.mode = mode
    def __enter__(self):
        print('启动装13模式,打开文件-->%s' % self.file)
        self.file = open(self.file, mode=self.mode)
        return self.file
    def __exit__(self, exc_type, exc_val, exc_tb):
        print('乱花从中过,片叶不沾身\n装完13,记得擦屁股啊')
        self.file.close()
# 依旧测试下在异常的情况下是否可以正常关闭文件
try:
    with zhuang13_open('a.txt', 'a+') as file:
        file.write('first line...')
        raise ValueError
except:
    os.rename('a.txt', 'b.txt')

完美结束....


了解下刚才的__exit__

刚才看到在定义__exit__方法时,自带了三个参数exc_type, exc_val, exc_tb

这是什么呢?分别为:异常类别,异常值,追踪信息,怎么看他的值呢?


把上面代码中raise ValueError改为1/0

__exit__方法中加入print(exc_type, exc_val, exc_tb)


得到如下结果:

<class 'ZeroDivisionError'> division by zero <traceback object at 0x00000000032BADC8>

大家会问到追踪信息是什么呢?其实大家天天见....当你代码错误了,提示哪一行有问题的时候,这个帮你定位的东西,就是追踪信息。

想看到追踪信息需要引入一个模块,traceback

继续在__exit__中添加这两行信息


import traceback

print(traceback.extract_tb(exc_tb))


output:

[('E:/Python/xxxx/b.py', 21, '<module>', 'raise ValueError')]

上面个list什么意思呢?  错误的文件,错误的行号,文件类型,错误的语句


是不是吊炸天?好了今天就学到这里,碎觉.....



相关文章
|
9月前
|
运维 监控 算法
时间序列异常检测:MSET-SPRT组合方法的原理和Python代码实现
MSET-SPRT是一种结合多元状态估计技术(MSET)与序贯概率比检验(SPRT)的混合框架,专为高维度、强关联数据流的异常检测设计。MSET通过历史数据建模估计系统预期状态,SPRT基于统计推断判定偏差显著性,二者协同实现精准高效的异常识别。本文以Python为例,展示其在模拟数据中的应用,证明其在工业监控、设备健康管理及网络安全等领域的可靠性与有效性。
1010 13
时间序列异常检测:MSET-SPRT组合方法的原理和Python代码实现
|
7月前
|
人工智能 C# Python
处理python异常
本文介绍了Python中的异常处理机制,并实现了一个简单的异常装饰器。通过`try/except`语句捕获异常,结合`finally`子句完成清理工作。为进一步优化代码结构,文章提出了使用装饰器处理异常的方法,避免函数中大量冗长的异常处理语句。通过类封装异常装饰器,多个函数可共享异常处理逻辑,提升代码简洁性和可维护性。总结强调了装饰器在异常处理中的优势,使代码更加优雅高效。
170 27
|
安全 Linux 网络安全
Kali 渗透测试:基于结构化异常处理的渗透-使用Python编写渗透模块(一)
Kali 渗透测试:基于结构化异常处理的渗透-使用Python编写渗透模块(一)
333 2
|
Python Windows 网络安全
Kali 渗透测试:基于结构化异常处理的渗透-使用Python编写渗透模块(二)
Kali 渗透测试:基于结构化异常处理的渗透-使用Python编写渗透模块(二)
236 2
|
9月前
|
数据采集 监控 Python
Python爬虫异常处理:自动跳过无效URL
Python爬虫异常处理:自动跳过无效URL
Python爬虫异常处理:自动跳过无效URL
|
8月前
|
Python
如何处理python的常见异常问题
在Python语言中,python异常处理机制主要依赖try、except、else、finally和raise五个关键字。本篇文章将为大家详细讲解一下如何处理python的常见异常问题。
|
10月前
|
人工智能 Shell 开发工具
[oeasy]python065python报错怎么办_try_试着来_except_发现异常
本文介绍了Python中处理异常的基本方法,重点讲解了`try`和`except`的用法。通过一个计算苹果重量的小程序示例,展示了如何捕获用户输入错误并进行处理。主要内容包括: 1. **回顾上次内容**:简要回顾了Shell环境、Python3游乐场和Vim编辑器的使用。 2. **编写程序**:编写了一个简单的程序来计算苹果的总重量,但发现由于输入类型问题导致结果错误。 3. **调试与修正**:通过调试发现输入函数返回的是字符串类型,需要将其转换为整数类型才能正确计算。
315 32
|
10月前
|
数据库 Python
[oeasy]python066_如何捕获多个异常_try_否则_else_exception
本文介绍了Python中`try...except...else`结构的使用方法。主要内容包括: 1. **回顾上次内容**:简要复习了`try`和`except`的基本用法,强调了异常处理的重要性。 2. **详细解释**: - `try`块用于尝试执行代码,一旦发现错误会立即终止并跳转到`except`块。 - `except`块用于捕获特定类型的异常,并进行相应的处理。 - `else`块在没有异常时执行,是可选的。 3. **示例代码**:通过具体例子展示了如何捕获不同类型的异常(如`ValueError`和`ZeroDivisionError`),并解释了异常处理
195 24
|
10月前
|
数据库连接 开发者 Python
Python中的异常处理
本文深入探讨了Python中的异常处理机制,包括异常的捕获、处理、抛出及最佳实践。通过try-except语句块,程序可以在运行时处理错误,增强健壮性和可维护性。文章还介绍了自定义异常类的创建与使用,并提供了代码示例和详细的语法说明。最后,总结了异常处理的最佳实践,如精确捕获异常、提供有用错误信息等,帮助开发者编写更可靠的代码。
354 14
|
10月前
|
人工智能 数据库 开发者
[oeasy]python068_异常处理之后做些什么_try语句的完全体_最终_finally
介绍了 Python 中 `try` 语句的完全体,包括 `try`、`except`、`else` 和 `finally` 子句的使用。通过实例展示了如何捕获异常并输出详细的错误信息,如文件名和行号。特别强调了 `finally` 子句的作用,无论是否发生异常,`finally` 都会执行,常用于清理操作。最后总结了 `try` 语句的四个部分及其应用场景,并简要提及了 Python 社区的决策机制。 #try #except #else #finally
174 1

推荐镜像

更多