Python
에서는 코드 실행 중 발생하는 비정상적인 상황을 표현하기 위해 예외 객체 (예외 객체)
를 사용합니다. 예외가 발생합니다. Python
中,使用异常对象(exception object)
来表示代码执行过程中所发生的异常情况,当执行程序爆出错误的时候则会抛出异常。
如果没有正确处理异常,则会终止运行。
你可以想象一下,如果你在开发一款产品时,出现异常而不报告出发生异常的原因,是不是会很难受,也很难解决异常的问题。
为了提高产品的稳定性与灵活性,Python
运行开发者捕捉并处理各类异常,一般的内部模块报错如KeyError异常类
较为常见,当然也有很多其他的。
简单了解下,Python将代码执行错误分为两类:语法错误(syntax error)
和异常(exception)
。
首先,是语法错误的问题。字面可知,代码解析错误。
这种错误通常出现在初学者,主要原因是所执行的代码不符合Python语法的规范,故会报出语法错误导致code停机。
下面给出一个错误示范:
>>> if for not in list(1,2,3,4) File "<stdin>", line 1 if for not in list(1,2,3,4) ^ SyntaxError: invalid syntax
从上面的报错中可以知道是语法错误,无效的语法。并且指出了错误的地方在for
的位置,很显然if
和for
不能用在一起。
异常则是在代码执行过程中发现的错误,这是很难提前被发现的,即使代码写的很规范标准,但也可能会出现执行异常的情况。
下面给出一个错误示例。在数学运算中,经常讨论的问题是除数为零的情况。然而,0作为除数是不被允许的,因为这样会导致异常情况。
>>> a = 5 / 0 Traceback (most recent call last): File "<stdin>", line 1, in <module> ZeroDivisionError: division by zero
很明显报错指出0作为除数是不对的。
当我们了解了错误和异常后,就得处理异常情况。对于语法错误这种问题多多练习即可避免,对于第二种异常,python
给出了try-except
语句来处理。
为了更清晰的解释,还是以上面的除数为0的情况作为例子,我们通过添加try-except
语句捕捉并处理异常情况:
def division(x, y): try: return x / y except ZeroDivisionError: print("0不能作为除数!!!")
然后我们再在terminal调用函数试试:
division(x=1, y=0)
输出:
0不能作为除数!!!
虽然我们的输入是错误的理论应该报错,但是并没有报错而且还返回了一段话。
下面解释一下try-except
语句的工作原理:
Try-except中的代码会被正常执行
如果没有出现异常则跳过except代码块并结束try-except
如果try-except中的某一句代码出现了问题异常,剩余代码停止执行,如果出现的异常与except所指定的一致,则执行except中的代码块,异常处理结束整个应用程序继续执行
如果出现的异常与except中指定的不符合,那么则跳出try语句,程序继续抛出异常并终止执行代码
当然,我们所编写的代码可能会出现多种异常情况,因此我们可以将所有的异常情况写在一个except语句块中,具体实现如下:
except (RuntimeError, TypeError, NameError):pass
如果捕捉到异常列表中的任意一项异常表达式,则都会进入except
오류 및 예외간략하게 소개하면 Python은 코드 실행 오류를 구문 오류제품의 안정성과 유연성을 향상시키기 위해
Python
은 개발자를 실행하여 다양한 예외를 캡처하고 처리합니다.KeyError 예외 클래스
와 같은 일반적인 내부 모듈 오류가 더 일반적입니다. 물론 다른 것들도 많이 있습니다.
(구문 오류)
와 예외 (예외)
의 두 가지 범주로 나눕니다.
위의 오류 보고서를 통해 구문 오류 및 잘못된 구문임을 알 수 있습니다. 그리고이런 종류의 오류는 주로 초보자에게 발생합니다. 가장 큰 이유는 실행 중인 코드가 Python 구문 사양을 따르지 않아 구문 오류가 보고되고 코드가 중지되기 때문입니다.
다음은 오류 예입니다.def passpass(x=1): try: return print(x+x) except (RuntimeError, TypeError, NameError): pass except TypeError: print('参数错误啦~') except NameError: print('名称错误啦~')
for
위치에 오류가 있음을 지적했습니다. 당연히 if
와 for
는 함께 사용할 수 없습니다.
오류와 예외를 이해한 후에는 예외를 처리해야 합니다. 두 번째 예외에 대해class A(Exception): pass class B(A): pass class C(B): pass for cls in [A, B, C]: try: raise cls() except C: print('C') except B: print('B') except A: print('A')분명히 오류 메시지는 0이 제수로 올바르지 않음을 나타냅니다.
예외 처리
python
은 이를 처리하기 위한 try-Exception
문을 제공하여 구문 오류와 같은 문제를 피할 수 있습니다. 더 명확한 설명을 위해 제수가 0인 위의 경우를 예로 들어보겠습니다. try-Exception
문을 추가하여 예외를 캡처하고 처리합니다.
class A(Exception): pass class B(A): pass class C(B): pass for cls in [A, B, C]: try: raise cls() except A: print('A') except B: print('B') except C: print('C')그런 다음 다음에서 함수를 호출합니다. 터미널 시도:
def passpass(x=1): try: return print(x/x) except TypeError: print('参数错误啦~') except NameError: print('名称错误啦~') except: print('报错啦~自己查')출력:
try-Exception
문의 작동 방식을 설명합니다.
try: pass except: pass else: pass🎜예외 목록의 예외 표현식이 발견되면
제외
처리에 들어갑니다. 🎜🎜물론, 각 예외를 개별적으로 처리하고 싶다면 하나씩 처리할 수도 있습니다. 🎜def passpass(x=1): try: return print(x/x) except TypeError as error: print('参数错误啦~', error) except NameError: print('名称错误啦~') except: print('报错啦~自己查')🎜🎜오늘은 여기서 업데이트하고 내일은 건너뛰겠습니다. 매일 롤 롤, 옛날 북경 치킨 롤 인사이드~ (2022.4.20)🎜🎜🎜파이썬의 예외 유형은 상속될 수 있습니다. 여기서만 제외하고 이전 예외를 상속받은 경우 후속 예외도 상속된다는 점만 알면 됩니다. , 예는 다음과 같습니다. 🎜
>>> raise NameError('HiThere') Traceback (most recent call last): File "<stdin>", line 1, in <module> NameError: HiThere🎜는 다음을 출력합니다. 🎜🎜🎜A🎜B🎜C🎜🎜🎜반대로, 예외 B와 C가 뒤바뀌면 A만 출력됩니다. 둘 다 A에서 상속되므로 B 예외를 포착한 후 종료됩니다. 🎜
class Error(Exception): """Base class for exception in this module.""" pass class InputError(Error): """Exception raised for errors in the input. Attributes: expression -- input expression in which the error occurred message -- explanation of the winerror """ def __init__(self, expression, message): self.expression = expression self.message = message🎜출력은 모두 A입니다. 🎜🎜🎜A🎜A🎜A🎜🎜🎜모든 예외를 하나씩 추출하면 이는 매우 이때 예외 유형이 예외로 설정되지 않으면 포착되지 않은 나머지 모든 예외가 포착됩니다. 🎜
def passpass(x=1): try: return print(x/x) except TypeError as error: print('参数错误啦~', error) except NameError: print('名称错误啦~') except: print('报错啦~自己查') finally: print('运算结束~')🎜중요한 기능: else.🎜🎜else 문은 다음과 같은 몇 가지 추가 작업을 수행하는 데 사용됩니다. try 코드 블록에서 실행됨 일부 파일 작업은 else에서 리소스를 해제할 수 있습니다. else의 구문 형식은 다음과 같습니다. 🎜rrreee🎜물론 다음과 같이 예외를 실행할 수도 있습니다. 🎜rrreee🎜예외를 독립적으로 발생시킵니다.🎜🎜개발자는 이를 수행하지 않습니다. 일부 정상적인 상황에서는 실행 오류가 발생하지만 이는 설계 논리를 따르지 않으므로 개발자가 적극적으로 예외를 발생시켜야 합니다. 이때 예외를 발생시키려면 raise 문을 사용해야 합니다. 🎜rrreee🎜Customized 예외🎜🎜 내장된 예외는 개발 요구 사항을 충족할 수 없으므로 예외를 사용자 정의할 수 있습니다. 🎜
自定义异常类必须要直接或间接继承自Exception类。尽管自定义异常类与其他类具有相同的功能,但为保持简洁,应该仅提高必要的属性。
class Error(Exception): """Base class for exception in this module.""" pass class InputError(Error): """Exception raised for errors in the input. Attributes: expression -- input expression in which the error occurred message -- explanation of the winerror """ def __init__(self, expression, message): self.expression = expression self.message = message
else在代码正常执行后才会被执行的代码块,但有些情况无论代码块是否出现异常都要执行,则需要用到finally语句:
def passpass(x=1): try: return print(x/x) except TypeError as error: print('参数错误啦~', error) except NameError: print('名称错误啦~') except: print('报错啦~自己查') finally: print('运算结束~')
위 내용은 Python 기본 튜토리얼에서 예외 처리 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!