Добавление переменного отступа перед каждой строкой вывода журнала PythonPython

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Добавление переменного отступа перед каждой строкой вывода журнала Python

Сообщение Anonymous »

Я создаю вход в приложение Python и хочу, чтобы оно было удобочитаемым для человека. На данный момент журналы отладки документируют каждую вызываемую функцию с аргументами и возвращаемыми значениями. Это означает, что практически журнал отладки для вызова вложенной функции может выглядеть так:

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

2024-07-29 16:52:26,641: DEBUG: MainController.initialize_components called with args 
2024-07-29 16:52:26,643: DEBUG: MainController.setup_connections called with args 
2024-07-29 16:52:26,645: DEBUG: MainController.setup_connections returned None
2024-07-29 16:52:26,646: DEBUG: MainController.initialize_components returned None
Я хотел бы, чтобы при чтении журналов было очевидно, когда что-то вложено, используя отступы в стиле Python. Итак, идеальный результат был бы таким:

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

2024-07-29 16:52:26,641: DEBUG: MainController.initialize_components called with args 
2024-07-29 16:52:26,643: DEBUG: MainController.setup_connections called with args 
2024-07-29 16:52:26,645: DEBUG: MainController.setup_connections returned None
2024-07-29 16:52:26,646: DEBUG: MainController.initialize_components returned None
В настоящее время я создаю свою документацию, обертывая методы класса этим декоратором:

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

import functools
import logging

def log(_func=None, *, logger):
def decorator_log(func):
@functools.wraps(func)
def wrapper(*args, **kwargs):
if logger.handlers:
current_formatter = logger.handlers[0].formatter
current_formatter.set_tabs(current_formatter.get_tabs() + 1)

self = args[0]
name = f'{self.__class__.__name__}.{func.__name__}'
if logger.root.level < logging.DEBUG:
logger.info(f"Entering {name}")
else:
args_repr = [repr(a) for a in args]
kwargs_repr = [f"{k}={v!r}" for k, v in kwargs.items()]
signature = ", ".join(args_repr + kwargs_repr)
logger.debug(f"{name} called with args {signature}")
try:
result = func(*args, **kwargs)
except Exception as e:
logger.exception(f"Exception raised in {name}: {str(e)}")
raise e
if logger.root.level < logging.DEBUG:
logger.info(f"Leaving {name}")
else:
logger.debug(f"{name} returned {result}")

if logger.handlers:
current_formatter = logger.handlers[0].formatter
current_formatter.set_tabs(current_formatter.get_tabs() - 1)

return result
return wrapper
if _func is None:
return decorator_log
else:
return decorator_log(_func)
Я мог бы добавить вкладки атрибутов в регистратор с помощью setattr и увеличить их в начале/уменьшить в конце декоратора, но это применимо только к вкладкам к части сообщения вывода, например:

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

2024-07-29 16:52:26,641: DEBUG: MainController.initialize_components called with args 
2024-07-29 16:52:26,643: DEBUG:     MainController.setup_connections called with args 
2024-07-29 16:52:26,645: DEBUG:     MainController.setup_connections returned None
2024-07-29 16:52:26,646: DEBUG: MainController.initialize_components returned None
Это лучше, чем ничего, но не совсем то, что я хочу. Как я могу обновить это (в идеале без использования глобальной переменной), чтобы иметь отступ переменной в начале каждой строки вывода журнала?

Подробнее здесь: https://stackoverflow.com/questions/788 ... ing-output
Реклама
Ответить Пред. темаСлед. тема

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

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

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

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

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Добавление переменного отступа перед каждой строкой вывода журнала Python
    Anonymous » » в форуме Python
    0 Ответы
    9 Просмотры
    Последнее сообщение Anonymous
  • Добавление переменного отступа перед каждой строкой вывода журнала Python
    Anonymous » » в форуме Python
    0 Ответы
    7 Просмотры
    Последнее сообщение Anonymous
  • SwiftUI TabView: добавление верхнего отступа к TabItems
    Гость » » в форуме IOS
    0 Ответы
    59 Просмотры
    Последнее сообщение Гость
  • Добавление верхнего отступа к элементу навигации при наведении смещает все элементы навигации. Попытка добиться эффекта
    Anonymous » » в форуме CSS
    0 Ответы
    91 Просмотры
    Последнее сообщение Anonymous
  • Добавление отступа к разделителю в композиции не работает
    Anonymous » » в форуме Android
    0 Ответы
    5 Просмотры
    Последнее сообщение Anonymous

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