최신 Python의 사용자 정의 예외 처리
Python에서 사용자 정의 예외 클래스를 정의하는 것은 오류를 관리하고 코드 안정성을 보장하는 데 필수적입니다. 이를 위한 적절한 접근 방식은 Python 버전에 비해 발전해 왔으며, 이 기사에서는 Python 2.5와의 호환성과 Python 2.6 및 3.* 표준 준수에 중점을 두고 "최신 Python"에 대한 권장 사항을 살펴봅니다.
사용자 정의 예외 선언
Python 2.6.2의 지원 중단 경고는 BaseException의 메시지 속성 설정이 다음과 같음을 나타냅니다. 낙담. PEP-352에 따르면 이 속성은 단계적으로 폐지되는 Python 2.5에서 특정한 의미를 가졌습니다. 따라서 사용자 정의 예외에서는 메시지를 속성 이름으로 사용하지 않아야 합니다.
대신 Exception의 __init__ 메서드를 재정의하여 원하는 메시지를 매개 변수로 전달하는 것이 좋습니다. 이를 통해 예외가 문자열로 변환될 때 자동으로 호출되는 예외의 __str__ 또는 __unicode__ 메서드를 통해 메시지에 액세스할 수 있습니다.
추가 데이터 전달
사용자 정의 예외에 추가 데이터를 포함하려면 __init__ 메서드에 추가 인수를 전달하는 것이 일반적입니다. 이러한 인수는 예외의 인스턴스 속성으로 저장되고 필요에 따라 액세스될 수 있습니다. Python 2에서는 기본 클래스의 생성자를 호출하려면 super()를 사용하여 명시적으로 슈퍼클래스 생성자를 호출해야 합니다.
예
사용자 정의의 더 자세한 예 예외:
class ValidationError(Exception): def __init__(self, message, errors): super().__init__(message) self.errors = errors
이 예에서 ValidationError 예외는 메시지와 오류 사전을 인수로 사용합니다. 오류 사전에는 오류에 대한 추가 정보가 포함될 수 있습니다. 예외가 포착된 코드에서 이 정보에 액세스하는 것이 이제 다음과 같이 간단해졌습니다.
try: # Code that may throw a ValidationError except ValidationError as e: print(f"Error: {e.message}") print(f"Errors: {e.errors}")
__init__ 및 __str__을 재정의하는 것이 더 많은 타이핑처럼 보일 수 있지만 모든 Python 버전과의 호환성을 보장하고 일관된 방법을 제공합니다. 예외 데이터에 액세스하는 중입니다.
위 내용은 최신 Python에서 사용자 정의 예외를 효과적으로 생성하고 처리하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!