이 기사에서는 Python의 예외 사항에 대해 설명합니다. Python의 예외에 대한 자세한 소개는 특정 참조 가치가 있습니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.
Python의 예외는 두 가지 유형으로 나누어집니다. 1) 구문 오류, Python 인터프리터의 구문 감지를 통과하지 못하면 코드를 실행할 수 없습니다. 2) 예외, Python 프로그램 실행 중에 감지되는 오류를 예외라고 합니다. 예외 처리가 이루어지지 않은 경우 프로그램이 종료되고, ①문자열을 숫자로 변환할 때 형식 변환 예외, ②파일을 읽을 때 파일이 존재하지 않음 예외, ③네트워크 연결 중 호스트에 연결할 수 없는 예외 등의 예외 정보가 표시됩니다. .. ·기다리다. Python 스크립트에서 예외가 발생하면 이를 포착하고 처리해야 합니다. 그렇지 않으면 프로그램이 실행을 종료합니다. 어쨌든 아무도 자신이 사용하는 프로그램이 갑자기 충돌하는 것을 원하지 않습니다
1. 구문 오류
Python 구문 오류는 많은 초보자가 자주 겪는 문제입니다. 코드를 몇 번 더 입력하면 이러한 오류를 줄일 수 있습니다. 6행 끝에 ")"가 너무 많습니다.
2. 예외
1) 런타임 중에 감지된 오류를 Python의 구문 감지에서는 이러한 오류를 확인할 수 없습니다.
>>> if Trur
File "<stdin>", line 1
if Trur
^
SyntaxError: invalid syntax
>>> print("as"))
File "<stdin>", line 1
print("as"))
^
SyntaxError: invalid syntax
1번째와 5번째 줄은 예외가 발생하는 곳입니다.
아래와 같이 예외의 출력 정보를 살펴보세요2) Python의 표준 예외 클래스
BaseException은 모든 예외의 기본 클래스이고 Exception은 일반 오류의 기본 클래스입니다.
기타
python 예외 클래스는 Baidu에서 하나씩 설명하지 않습니다3. 예외 처리
프로그램의 견고성을 향상시키고 예외 발생 시 프로그램이 충돌하는 것을 방지하기 위해 필요할 때 예외 처리가 필요합니다
1) try-Exception: 문
①, the 가장 간단한 예외 처리 문은 다음과 같습니다. try 문 블록에서 예외가 발생하면 다음 문은 더 이상 실행되지 않습니다(라인 3). 실행합니다(3번째 줄에서와 같이). 참고: Except 뒤에는 예외 유형이 없습니다. 기본적으로 모든 예외가 캡처됩니다.
>>> int("aa") Traceback (most recent call last): File "<stdin>", line 1, in <module> ValueError: invalid literal for int() with base 10: 'aa' >>> f = open("aaa.txt","r") Traceback (most recent call last): File "<stdin>", line 1, in <module> FileNotFoundError: [Errno 2] No such file or directory: 'aaa.txt'
②. 다양한 예외를 캡처해야 하는 경우 이를 달성하기 위해 여러 예외를 사용할 수 있습니다. 예외 정보를 얻으려면 7행
try: int("aaa") print("---aaa---") except: print("出现异常-->英文字母不能转换为数字") print("----------") # 输出结果 出现异常-->英文字母不能转换为数字 ----------
3과 같이 변수 이름이 예외 개체를 가져오므로 다음과 같이 사용할 수 있습니다. 동일한 방식으로 여러 예외를 처리해야 하는 경우, Except(ValueError, [ZeropisionError [, NameError]]):
try:
nu = int("100")
print("转换后的值nu:", nu)
i = 1 / 0
except ValueError:
print("出现异常-->英文字母不能转换为数字")
except ZeroDivisionError as e: # 通过 as 变量名 获取异常的对象
print("出现异常-->除数不能为零")
print("异常的提示信息-->", e)
except:
pass
print("----------")
# 输出结果
转换后的值nu: 100
出现异常-->除数不能为零
异常的提示信息--> division by zero
----------
① try-excess-else-finally에 finally 문이 나타나면 finally 문 블록의 문은 예외 발생 여부에 관계없이 반드시 실행되며, else 문은 예외가 발생하지 않은 경우에만 실행됩니다. 예외가 발생하면 try-Exception-else-finally도 다음과 같습니다. 별도로 사용할 수 있는 형식은 1) try-event-finally 2) try-read-else 3) try-finally입니다. 코드는 여기에 표시되지 않습니다
4. 예외 전달
예외가 발생한 명령문에는 예외 처리 명령문을 만날 때까지 예외가 상위 계층으로 전달됩니다. Python 인터프리터는 Program
try: i = 1 / 0 nu = int("aa") except (ValueError, ZeroDivisionError) as e: print(e) except: pass print("----------") # 输出结果 division by zero ----------
을 종료합니다. 위에 표시된 것처럼 test2의 2번째 라인에서 예외가 발생하면 5번째 라인에서 test2를 호출하는 명령문으로 전달됩니다. 여기에는 아직 예외 처리 명령문이 없으며, 계속해서 상위 레이어로 전달되고 8번째 줄을 제외하고 잡힙니다
5. 예외 던지기 raise
1) Python에서 정의한 예외를 던집니다
예외 유형 및 던져진 예외도 예외에 의해 포착됩니다. 아래 4번째 줄에 표시된 대로
try:
i = 1 / 0
print("没有出现异常i值", i)
except Exception as e:
print("出现异常-->", e)
else:
print("没有出现异常-->执行else")
finally:
print("不管是否出现异常,这里的语句一定会被执行")
# 输出结果
出现异常--> division by zero
不管是否出现异常,这里的语句一定会被执行
抛出自定义异常首先得有个自定义的异常类,注:自定义的异常必须直接或间接的继承Exception基类
class MyException(Exception): # 自定义异常类 def __init__(self, msg): self.msg = msg age = 500 try: if age < 0 or age > 200: raise MyException("age范围0-200") # 抛出自定义异常 print("age", age) except MyException as e: print("出现异常-->", e) # 输出结果 出现异常--> age范围0-200
当然自定义异常类也可以拥有许多的功能,就得看需求添加啦
6、在异常处理中抛出异常
有某需求:当捕获到异常时处理完后想继续抛出异常.....
在except中用raise可以抛出当前异常
try: i = 1 / 0 # 异常的语句 except Exception as e: print("出现异常-->", e) raise # 处理完后继续抛出异常,raise表示抛出当前异常 print("-------------") # 输出结果 出现异常--> division by zero Traceback (most recent call last): File "<stdin>", line 2, in <module> i = 1 / 0 ZeroDivisionError: division by zero
위 내용은 파이썬의 예외는 무엇입니까? Python의 예외에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!