Как получить обратную трассировку из модуля с помощью декоратора?Python

Программы на Python
Ответить
Anonymous
 Как получить обратную трассировку из модуля с помощью декоратора?

Сообщение Anonymous »

У меня есть декоратор в корне пакета, который должен выводить информацию о непредвиденных исключениях.

Код: Выделить всё

from logging import getLogger
from os.path import basename
from traceback import extract_tb

logSys = getLogger()

def catchUnexpectedError(funct):

def wrapper():
try:
funct()

except Exception as unknown:
tb = extract_tb(unknown.__traceback__)[0]
exc, msg = repr(unknown).rstrip(')').split('(', maxsplit=1)

logSys.critical(f'Execution finished by exception {exc}: {msg.strip(chr(34))}.')
logSys.critical(f'Exception caused by: {tb.line} (line {tb.lineno}) at {basename(tb.filename)}')

return wrapper
Проблема в том, что информация трассировки указывает на файл/строки, в которых объявлен декоратор, а не на модуль, вызвавший остановку скрипта.

Код: Выделить всё

@catchUnexpectedError
def hello(name):
print(f'Good morning {name}!')

hello()

Код: Выделить всё

[CRITICAL] Execution finished by exception TypeError: hello() missing 1 required positional argument: 'name'. (15:49:26 28/10/2025)
[CRITICAL] Exception caused by: funct() (line 51) at __init__.py (15:49:26 28/10/2025)
Есть ли способ обойти это или это в корне неверно?


Подробнее здесь: https://stackoverflow.com/questions/798 ... -decorator
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»