명명된 예외와 관련된 NameError 및 UnboundLocalError 문제 이해
Python 2.x에서 아래 코드 조각은 명명된 예외의 값을 적절하게 인쇄했습니다. 예외 블록 외부의 예외, 예외:
<code class="python">exc = None try: raise Exception except Exception as exc: pass print(exc)</code>
그러나 Python 3.x에서 동일한 코드를 시도하면 NameError(또는 함수 컨텍스트에서는 UnboundLocalError)가 발생합니다. 이 문제를 해결하려면 Python의 업데이트된 동작에 대한 이론적 근거를 파악하는 것이 중요합니다.
Python 3.x 예외 범위 및 정리
Python 3.x의 제외 문 순환 참조 및 조기 가비지 수집을 방지하기 위해 바인딩된 예외의 범위를 명시적으로 제한합니다. as 구문을 사용하여 예외를 할당하면 Except 절 끝에서 지워집니다. 이를 위해서는 추가 액세스를 위해 예외를 제외 블록 외부의 다른 이름에 할당해야 합니다.
exc = ex를 단순히 다시 할당하는 것만으로는 충분하지 않습니다. 왜냐하면 제외 절은 새 범위를 생성하지 않기 때문입니다. 대신, 현재 예외 할당에 지정된 이름을 현재 이름에서 제거합니다.
과거 컨텍스트 및 Python 2.x 동작
Python 2.x에서는 예외가 발생했습니다. 트레이스백에 대한 참조를 보유하지 않으므로 Python 3.x에서와 같이 엄격한 정리가 필요하지 않습니다. 순환 참조가 없기 때문에 문제를 일으키지 않고 예외를 제외 블록 외부의 명명된 변수에 바인딩할 수 있었습니다.
예외 처리에 대한 권장 사항
Python 3에서 예외를 효과적으로 처리하려면 .x에서는 다음 지침을 권장합니다:
다음 코드는 이러한 권장 사항을 예시합니다.
<code class="python">try: raise Exception("foo") except Exception as e: exc = e # Bind to a new variable exc.__traceback__ = None # Explicitly clear traceback</code>
이러한 방식을 준수하면 Python 3.x에서 예외를 자신 있게 처리하고 액세스하여 함정을 피할 수 있습니다. NameError 및 UnboundLocalError에 의해 제기되었습니다.
위 내용은 Python 3.x에서 예외를 처리할 때 NameError 또는 UnboundLocalError가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!