异常的处理
异常的定位

 
常见异常的解决
| 报错内容 | 含义 | 
|---|---|
| SyntaxError | 语法错误 | 
| NameError | 尝试访问一个没有申明的变量 | 
| ZeroDivisionError | 除数为 0 错误(零除错误) | 
| ValueError | 数值错误 | 
| TypeError | 类型错误 | 
| AttributeError | 访问对象的不存在的属性 | 
| IndexError | 索引越界异常 | 
| KeyError | 字典的关键字不存在 | 
能看懂即可
| 异常名称 | 说明 | 
|---|---|
| ArithmeticError | 所有数值计算错误的基类 | 
| AssertionError | 断言语句失败 | 
| AttributeError | 对象没有这个属性 | 
| BaseException | 所有异常的基类 | 
| DeprecationWarning | 关于被弃用的特征的警告 | 
| EnvironmentError | 操作系统错误的基类 | 
| EOFError | 没有内建输入,到达 EOF 标记 | 
| Exception | 常规错误的基类 | 
| FloatingPointError | 浮点计算错误 | 
| FutureWarning | 关于构造将来语义会有改变的警告 | 
| GeneratorExit | 生成器(generator)发生异常来通知退出 | 
| ImportError | 导入模块/对象失败 | 
| IndentationError | 缩进错误 | 
| IndexError | 序列中没有此索引(index) | 
| IOError | 输入/输出操作失败 | 
| KeyboardInterrupt | 用户中断执行(通常是输入^C) | 
| KeyError | 映射中没有这个键 | 
| LookupError | 无效数据查询的基类 | 
| MemoryError | 内存溢出错误(对于 Python 解释器不是致命的) | 
| NameError | 未声明/初始化对象 (没有属性) | 
| NotImplementedError | 尚未实现的方法 | 
| OSError | 操作系统错误 | 
| OverflowError | 数值运算超出最大限制 | 
| OverflowWarning | 旧的关于自动提升为长整型(long)的警告 | 
| PendingDeprecationWarning | 关于特性将会被废弃的警告 | 
| ReferenceError | 弱引用(Weak reference)试图访问已经垃圾回收了的对象 | 
| RuntimeError | 一般的运行时错误 | 
| RuntimeWarning | 可疑的运行时行为(runtime behavior)的警告 | 
| StandardError | 所有的内建标准异常的基类 | 
| StopIteration | 迭代器没有更多的值 | 
| SyntaxError Python | 语法错误 | 
| SyntaxWarning | 可疑的语法的警告 | 
| SystemError | 一般的解释器系统错误 | 
| SystemExit | 解释器请求退出 | 
| TabError Tab | 和空格混用 | 
| TypeError | 对类型无效的操作 | 
| UnboundLocalError | 访问未初始化的本地变量 | 
| UnicodeDecodeError Unicode | 解码时的错误 | 
| UnicodeEncodeError Unicode | 编码时错误 | 
| UnicodeError Unicode | 相关的错误 | 
| UnicodeTranslateError Unicode | 转换时错误 | 
| UserWarning | 用户代码生成的警告 | 
| ValueError | 传入无效的参数 | 
| Warning | 警告的基类 | 
| WindowsError | 系统调用失败 | 
| ZeroDivisionError | 除(或取模)零 (所有数据类型) | 
try…一个except结构
try:
	被监控的可能发生异常的语句块
except BaseException[as e]:
	异常处理语句块
如果监控的语句块中存在异常,那么执行到异常语句后会跳过后面的语句转到except的语句继续执行。
 BaseException是默认的一个类,它可以提供异常信息。你可以选择不使用它。
 例如:
try:
	print('1')
	a=1/0
	print('2')
except :
	print('3')
可以看到遇到异常后跳过了2而直接执行了3。
 
 如果没有异常就不会执行except中的内容。
 
 我们再来试一下BaseException
 
try…多个except结构
try:
	被监控的可能发生异常的语句块
except Exception1:
	异常处理语句块1
except Exception2:
	异常处理语句块2
except Exception3:
	异常处理语句块3
注意,如果Exception之间存在子类父类关系,需要将子类放在父类前面。
 多个except结构相当于把BaseException拆分成多个小的模块来分类处理。
try…except…else结构
try:
	被监控的可能发生异常的语句块
except Exception:
	异常处理语句块
else:
	语句块
如果出现异常,执行except中内容,否则执行else中内容。
try…except…finally结构
try:
	被监控的可能发生异常的语句块
except Exception:
	异常处理语句块
else:
	语句块
finally:
	语句块
无论异常发生与否,finally语句块都执行。一般用于关闭try中打开的资源来减少资源占用。
with上下文管理
with context_expr [ as var]:
	语句块
with中使用context_exp打开文件、进行赋值等操作,然后执行语句块内容,无论是否报错,with 结束后会关闭所有这里打开的资源。
traceback模块
使用traceback模块打印异常信息。
 例如:
import traceback
try:
	a=1/0
except:
	traceback.print_exc()
就可以实现正常输入1/0时一样的报错。使用这个模块就可以在try结构中引入详细的错误反馈。
 如果写traceback.print_exc(file=文件地址.格式,a")则会创建或在该文件中打印错误信息。
自定义异常类
通常继承Exception或者子类即可。命名一般以Error、Exception为后缀。以raise语句主动抛出。
 创建的方法
class SometypeErroe(Exception):
	def __init__(self,errorInfo):
		Exception.__init__(self)
		self.errorInfo=errorInfo
	def __str__(self):
		return str(self.errorInfo)+'你想说的内容'
测试
class SometypeErroe(Exception):
	def __init__(self,errorInfo):
		Exception.__init__(self)
		self.errorInfo=errorInfo
	def __str__(self):
		return str(self.errorInfo)+'你想说的内容'
a=int(input('输入'))
if 10<a<50:
	print(a)
else:
	raise SometypeErroe(a)

pycharm开发环境的调试
关键是设置断点,观察程序的运行状态。
 在对应语句前单击可以设置断点,再次单击可以取消。
 
 进入调试模式:
 1.右键debug
 
 2.或者点栏上的虫子
 
 进入debug模式后,蓝色条表示程序已经进行到这里
 线程在后面才讲。
 
 
 各个快捷键的含义
 
 
 
转载:https://blog.csdn.net/Temmie1024/article/details/115921003
