Python에서 어설 션을 비활성화하려면 어떻게해야합니까?
즉, 어설 션이 실패하면를 던지지 AssertionError
않고 계속 진행하기 를 원합니다 .
어떻게하나요?
답변:
Python에서 어설 션을 비활성화하려면 어떻게해야합니까?
단일 프로세스, 환경 또는 한 줄의 코드에 영향을 미치는 여러 접근 방식이 있습니다.
각각을 시연합니다.
은 Using -O
플래그 (자본 O은) 프로세스의 모든 어설 문을 사용할 수 없습니다.
예를 들면 :
$ python -Oc "assert False"
$ python -c "assert False"
Traceback (most recent call last):
File "<string>", line 1, in <module>
AssertionError
비활성화하면 다음과 같은 표현식도 실행되지 않습니다.
$ python -Oc "assert 1/0"
$ python -c "assert 1/0"
Traceback (most recent call last):
File "<string>", line 1, in <module>
ZeroDivisionError: integer division or modulo by zero
환경 변수를 사용하여이 플래그를 설정할 수도 있습니다.
이것은 환경을 사용하거나 상속하는 모든 프로세스에 영향을 미칩니다.
예를 들어 Windows에서 환경 변수를 설정하고 지 웁니다.
C:\>python -c "assert False"
Traceback (most recent call last):
File "<string>", line 1, in <module>
AssertionError
C:\>SET PYTHONOPTIMIZE=TRUE
C:\>python -c "assert False"
C:\>SET PYTHONOPTIMIZE=
C:\>python -c "assert False"
Traceback (most recent call last):
File "<string>", line 1, in <module>
AssertionError
Unix에서 동일 (set 및 unset 사용 각 기능에 대해 )
질문을 계속합니다.
어설 션이 실패하면 AssertionError를 던지지 않고 계속 진행하기를 원합니다.
실행에 실패한 코드를 원하는 경우 제어 흐름이 어설 션에 도달하지 않는지 확인할 수 있습니다. 예를 들면 다음과 같습니다.
if False:
assert False, "we know this fails, but we don't get here"
또는 어설 션 오류를 잡을 수 있습니다.
try:
assert False, "this code runs, fails, and the exception is caught"
except AssertionError as e:
print(repr(e))
인쇄 :
AssertionError('this code runs, fails, and the exception is caught')
그리고 당신은 당신이 AssertionError
.
다음과 같은 assert 문 :
assert expression #, optional_message
다음과 같습니다.
if __debug__:
if not expression: raise AssertionError #(optional_message)
과,
내장 변수
__debug__
는 최적화가 요청 될 때True
정상적인 상황에 있습니다False
(명령 행 옵션-O
).
그리고 더
에 대한 할당
__debug__
은 불법입니다. 내장 변수의 값은 인터프리터가 시작될 때 결정됩니다.
사용법 문서에서 :
기본 최적화를 켭니다. 이렇게하면 컴파일 된 (바이트 코드) 파일의 파일 이름 확장자가 .pyc에서 .pyo로 변경됩니다. PYTHONOPTIMIZE도 참조하십시오.
과
비어 있지 않은 문자열로 설정하면
-O
옵션 을 지정하는 것과 같습니다 . 정수로 설정하면-O
여러 번 지정 하는 것과 같습니다 .
if False: assert False
하거나 (예 :) Assertion 오류를 포착 할 수 있습니다. 이것이 당신의 선택입니다. 질문을 해결하기 위해 답변을 업데이트했습니다.
foo()
됩니다 with skip_assertion(): foo()
. 이것의 이점은 내가 함수에 다른 플래그를 추가 할 필요가 없다는 것입니다
Assert
개체를 Pass
개체로 대체 ). 컨텍스트 관리자는이를 위해 직접 작동하지 않지만 그런 방식으로 데코 레이팅 된 함수를 사용하는 일종의 메커니즘을 가질 수 있습니다. 어쨌든 나는 그것을 권장하지 않습니다. 그렇게하려는 이유는 제어하지 않는 코드를 호출하고 AssertionErrors가 발생하기 때문이라고 생각합니다. 그렇다면 다른 해결책을 찾아야 할 것입니다.
-O 플래그를 사용하여 Python을 호출합니다.
test.py :
assert(False)
print 'Done'
산출:
C:\temp\py>C:\Python26\python.exe test.py
Traceback (most recent call last):
File "test.py", line 1, in <module>
assert(False)
AssertionError
C:\temp\py>C:\Python26\python.exe -O test.py
Done
이미 주어진 두 답변 모두 유효합니다 ( -O
또는 -OO
명령 줄에서 Python을 호출 ).
그들 사이의 차이점은 다음과 같습니다.
-O
기본 최적화를 켭니다. 이렇게하면 컴파일 된 (바이트 코드) 파일의 파일 이름 확장자가 .pyc에서 .pyo로 변경됩니다.
-OO
폐기 문서화 문자열 뿐만 아니라 받는 -O
최적화.
( Python 문서에서 )
당신은해야 하지 비활성화 (대부분의) 주장. 주의가 다른 곳에있을 때 예상치 못한 오류를 포착합니다. "10의 거듭 제곱"의 규칙 5를 참조하십시오 .
대신 다음과 같이 값 비싼 어설 션 검사를 보호하십시오.
import logging
logger = logging.getLogger(__name__)
if logger.getEffectiveLevel() < logging.DEBUG:
ok = check_expensive_property()
assert ok, 'Run !'
중요한 단언을 유지하고 assert
문을 최적화 할 수있는 한 가지 방법 은 선택 문 내에서 문을 올리는 것입니다.
if foo_is_broken():
raise AssertionError('Foo is broken!')
__debug__
False로 설정하려고했지만 허용되지 않습니다.