Mari kita membuat stacktrace yang cukup rumit, untuk menunjukkan bahwa kita mendapatkan stacktrace lengkap:
def raise_error():
raise RuntimeError('something bad happened!')
def do_something_that_might_error():
raise_error()
Logout stacktrace penuh
Praktik terbaik adalah membuat logger diatur untuk modul Anda. Ia akan mengetahui nama modul dan dapat mengubah level (di antara atribut lainnya, seperti penangan)
import logging
logging.basicConfig(level=logging.DEBUG)
logger = logging.getLogger(__name__)
Dan kita bisa menggunakan logger ini untuk mendapatkan kesalahan:
try:
do_something_that_might_error()
except Exception as error:
logger.exception(error)
Log mana:
ERROR:__main__:something bad happened!
Traceback (most recent call last):
File "<stdin>", line 2, in <module>
File "<stdin>", line 2, in do_something_that_might_error
File "<stdin>", line 2, in raise_error
RuntimeError: something bad happened!
Jadi kami mendapatkan output yang sama seperti ketika kami memiliki kesalahan:
>>> do_something_that_might_error()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "<stdin>", line 2, in do_something_that_might_error
File "<stdin>", line 2, in raise_error
RuntimeError: something bad happened!
Hanya mendapatkan string
Jika Anda benar-benar hanya menginginkan string, gunakan traceback.format_exc
fungsinya sebagai gantinya, menunjukkan pendataan string di sini:
import traceback
try:
do_something_that_might_error()
except Exception as error:
just_the_string = traceback.format_exc()
logger.debug(just_the_string)
Log mana:
DEBUG:__main__:Traceback (most recent call last):
File "<stdin>", line 2, in <module>
File "<stdin>", line 2, in do_something_that_might_error
File "<stdin>", line 2, in raise_error
RuntimeError: something bad happened!
log_error(err)
fungsi.