Python에서 예외 범위 및 바인딩된 예외 할당
Python에서는 Except 블록이 끝난 후 명명된 예외의 범위를 이해하는 것이 중요합니다. 이는 Python 2.x와 3.x 동작을 비교할 때 분명해집니다.
Python 3.x 동작: NameError 및 UnboundLocalError
Python 3.x에서 해당 블록 외부의 Except 블록에 명명된 예외에 액세스하면 NameError(함수 외부에서 액세스되는 경우) 또는 UnboundLocalError(함수 내부에서 액세스되는 경우)가 발생합니다.
변경 이유
이 변경 사항은 제외 절 내에서 명명된 예외의 범위를 명시적으로 제한하려는 Python 3.x의 결정 때문입니다. 이는 순환 참조를 방지하고 역추적을 명시적으로 정리할 필요를 피하기 위한 것입니다.
해결 방법
except 블록 외부의 예외에 액세스하려면 해당 예외를 다음에 다시 바인딩해야 합니다. 새로운 이름. 예:
<code class="python">exc = None try: raise Exception except Exception as exc: exc = exc # Rebinding to a new name</code>
명시적 역추적 지우기
원하는 경우 예외를 다시 바인딩한 후 명시적으로 역추적을 지울 수 있습니다.
<code class="python">exc = None try: raise Exception("foo") except Exception as e: exc = e exc.__traceback__ = None</code>
Python 2.x와의 대조
Python 2.x에서는 예외에 트레이스백에 대한 참조가 포함되지 않았으므로 이러한 범위 제한이 필요하지 않았습니다. 결과적으로, 제외 블록 뒤의 변수에 예외를 할당해도 부정적인 결과는 발생하지 않았습니다.
위 내용은 Python 2.x와 3.x에서 명명된 예외의 범위는 어떻게 다릅니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!