暂无分类
暂无标签
发布于2019-10-27 09:40 阅读(783) 评论(0) 点赞(29) 收藏(3)
0
1
2
3
4
5
6
(这种错误,根本过不了Python解释器的语法检测,必须在程序执行前就改正)
# 语法错误示范
print(111
[1;2;3;4]
# 逻辑错误示例
lst = [1,2,3]
lst[5]
dic = {"key":1}
dic["name"]
1 + "alex"
int("alex")
name = "alex"
def func():
print(name)
name = "a"
func()
(异常就是在语法上是没有问题,但是运行时就报错的称为异常, 异常发生之后剩余代码将不会继续执行)
在python中不同的异常可以用不同的类型(Python中统一了类与类型,类型即类)去标识,不同的类对象标识不同的异常,一个异常标识一种错误
异常类型 | 异常描述 |
---|---|
AttributeError | 试图访问一个对象没有的属性,例如f.x 但是f没有属性x |
ImportError | 无法引入模块或包;基本上是路径问题或名称错误 |
IndentationError | 代码没有正确对齐 |
IndexError | 下标索引超出序列索引边界 |
KeyError | 试图访问字典里不存在的键 |
NameError | 使用一个还未被赋予对象的变量 |
SyntaxError | Python遇到非法代码,代码不能编译 |
TypeError | 传入对象类型与要求的不符合 |
UnboundLocalError | 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量 |
ValueError | 传入一个调用者不期望的值,即使值的类型是正确的 |
更多异常:
ArithmeticError
AssertionError
AttributeError
BaseException
BufferError
BytesWarning
DeprecationWarning
EnvironmentError
EOFError
Exception
FloatingPointError
FutureWarning
GeneratorExit
ImportError
ImportWarning
IndentationError
IndexError
IOError
KeyboardInterrupt
KeyError
LookupError
MemoryError
NameError
NotImplementedError
OSError
OverflowError
PendingDeprecationWarning
ReferenceError
RuntimeError
RuntimeWarning
StandardError
StopIteration
SyntaxError
SyntaxWarning
SystemError
SystemExit
TabError
TypeError
UnboundLocalError
UnicodeDecodeError
UnicodeEncodeError
UnicodeError
UnicodeTranslateError
UnicodeWarning
UserWarning
ValueError
Warning
ZeroDivisionError
检测到异常后“跳”过异常及异常下的代码,保证程序不会被中断
num = input(">>")
if num.isdecimal():
int(num)
if len(num) == 0:
pass
# if 处理一些简单的异常,if异常处理的方式
总结:
if判断式的异常处理只能针对某一段代码,对于不同的代码段的相同类型的错误你需要写重复的if来进行处理。
在你的程序中频繁的写与程序本身无关,与异常处理有关的if,会使得你的代码可读性极其的差
if是可以解决异常的,只是存在1,2的问题,所以,千万不要妄下定论 if 不能用来异常处理
try: # 尝试
int("alex")
except ValueError:
"""其他代码逻辑"""
try:
[1,2,3][7]
print(111)
dic = {"key":1}
dic["name"]
except Exception: # 万能异常 -- Exception , 可以捕获任意异常
pass
try:
int(input("请输入数字:"))
except ValueError as e: # as相当于将报错信息赋值给了e
print(e)
try:
int(input("请输入数字:"))
except Exception as e:
print(e)
int(input("请输入数字:"))
try:
num = int(input("请输入数字:"))
lst = [1,2,3]
# dic = {"name":"mee",1:"imo"}
# print(dic[num])
print(lst[num])
except ValueError as e:
print(e)
except KeyError as e:
print(f"没有{e}这个键")
except IndexError as e:
print(e)
except Exception as e:
print(e)
else:
print("都没有错,走我!")
finally:
print("有错没有错,都走我!,清理工作")
class EvaException(BaseException):
def __init__(self,msg):
self.msg = msg
def __str__(self):
return self.msg
try:
a = EvaException('类型错误')
raise a
except EvaException as e:
print(e)
把错误处理和真正的工作分开来
代码更易组织,更清晰,复杂的工作任务更容易实现;
毫无疑问,更安全了,不至于由于一些小的疏忽而使程序意外崩溃了;
try...except应该尽量少用,因为它本身就是你附加给你的程序的一种异常处理的逻辑,与你的主要的工作是没有关系的这种东西加的多了,会导致你的代码可读性变差,只有在有些异常无法预知的情况下,才应该加上try...except,其他的逻辑错误应该尽量修正
assert 1 == 1
if 1 == 1:
print(111)
assert 1 == 2
if 1 == 2:
print(222)
0
1
2
3
4
5
作者:9384vfnv
链接: https://www.pythonheidong.com/blog/article/145990/6734572a52d00d695a27/
来源: python黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
Copyright © 2018-2021 python黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-1
投诉与举报,广告合作请联系z452as@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!