traceback을 이용하여 에러에 대한 Strack trace 출력 방법을 소개합니다.
문제 상황
아래 코드는 integer 객체를 배열로 접근하여 Exception이 발생하고 프로그램이 종료됩니다.
A = 10
value = A[5]
Output:
Traceback (most recent call last):
File "/home/js/IdeaProjects/python-ex/stacktrace.py", line 11, in <module>
value = A[5]
TypeError: 'int' object is not subscriptable
프로그램이 종료되는 것은 막고 싶어 try-except로 로그만 출력하고, 에러는 무시하도록 다음과 같이 구현했습니다. 하지만 단순히 로그만 출력되어, 어떤 에러가 발생했는지, 어떤 코드에서 에러가 발생했는지 확인이 어렵습니다.
try:
A = 10
value = A[5]
except:
print("Ignore exception")
Output:
Ignore exception
traceback으로 Stack trace 출력
traceback의 print_exc()
는 에러에 대한 Strack trace를 출력합니다.
프로그램을 종료시키지 않고, 에러에 대한 자세한 로그를 출력할 수 있습니다.
import traceback
A = 10
try:
value = A[5]
except:
traceback.print_exc()
print("Program is not terminated")
Output:
Traceback (most recent call last):
File "/home/js/IdeaProjects/python-ex/stacktrace.py", line 5, in <module>
value = A[5]
TypeError: 'int' object is not subscriptable
Program is not terminated
Loading script...
Related Posts
- Python - Yaml 파일 파싱하는 방법
- Python - 파일 내용 삭제
- Python - for문에서 리스트 순회 중 요소 값 제거
- Python - 두 리스트에서 공통 요소 값 찾기
- Python - 문자열 앞(뒤)에 0으로 채우기
- Python - 공백으로 문자열 분리
- Python - 중첩 리스트 평탄화(1차원 리스트 변환)
- Python - 16진수 문자열을 Int로 변환
- Python - 두 날짜, 시간 비교
- Python f-string으로 변수 이름, 값 쉽게 출력 (변수명 = )
- Python - nonlocal과 global 사용 방법
- Python 바다코끼리 연산자 := 알아보기
- Python - pip와 requirements.txt로 패키지 관리
- Python - 딕셔너리 보기 좋게 출력 (pprint)
- Python - Requests 사용 방법 (GET/POST/PUT/PATCH/DELETE)
- Python - 온라인 컴파일러 사이트 추천
- Python - os.walk()를 사용하여 디렉토리, 파일 탐색
- Python - 문자열 비교 방법
- Python - Text 파일 읽고 쓰는 방법 (read, write, append)
- Python - 리스트에서 첫번째, 마지막 요소 가져오는 방법
- Python - 두개의 리스트 하나로 합치기
- Python - 리스트의 마지막 요소 제거
- Python - 리스트의 첫번째 요소 제거
- Python 소수점 버림, 4가지 방법
- Python 코드 안에서 버전 확인 방법
- Python 소수점 반올림, round() 예제
- Python - 리스트 평균 구하기, 3가지 방법
- Python - bytes를 String으로 변환하는 방법
- Python - String을 bytes로 변환하는 방법
- Python 버전 확인 방법 (터미널, cmd 명령어)
- Python - 람다(Lambda) 함수 사용 방법
- Python - dict 정렬 (Key, Value로 sorting)
- Python - range() 사용 방법 및 예제
- Python - 리스트를 문자열로 변환
- Python - 문자를 숫자로 변환 (String to Integer, Float)