logging — Logging facility for Python

Source code: Lib/logging/__init__.py


Este módulo define funciones y clases que implementan un sistema flexible de logging de eventos para aplicaciones y bibliotecas.

El beneficio clave de tener la API de logging proporcionada por un módulo de la biblioteca estándar es que todos los módulos de Python pueden participar en el logging, por lo que el registro de su aplicación puede incluir sus propios mensajes integrados con mensajes de módulos de terceros.

Here’s a simple example of idiomatic usage:

# myapp.py
import logging
import mylib
logger = logging.getLogger(__name__)

def main():
    logging.basicConfig(filename='myapp.log', level=logging.INFO)
    logger.info('Started')
    mylib.do_something()
    logger.info('Finished')

if __name__ == '__main__':
    main()
# mylib.py
import logging
logger = logging.getLogger(__name__)

def do_something():
    logger.info('Doing something')

If you run myapp.py, you should see this in myapp.log:

INFO:__main__:Started
INFO:mylib:Doing something
INFO:__main__:Finished

The key feature of this idiomatic usage is that the majority of code is simply creating a module level logger with getLogger(__name__), and using that logger to do any needed logging. This is concise, while allowing downstream code fine-grained control if needed. Logged messages to the module-level logger get forwarded to handlers of loggers in higher-level modules, all the way up to the highest-level logger known as the root logger; this approach is known as hierarchical logging.

For logging to be useful, it needs to be configured: setting the levels and destinations for each logger, potentially changing how specific modules log, often based on command-line arguments or application configuration. In most cases, like the one above, only the root logger needs to be so configured, since all the lower level loggers at module level eventually forward their messages to its handlers. basicConfig() provides a quick way to configure the root logger that handles many use cases.

El módulo proporciona mucha funcionalidad y flexibilidad. Si no está familiarizado con logging, la mejor manera de familiarizarse con él es ver los tutoriales (vea los enlaces arriba a la derecha).

The basic classes defined by the module, together with their attributes and methods, are listed in the sections below.

  • Los loggers exponen la interfaz que el código de la aplicación usa directamente.

  • Los gestores envían los registros (creados por los loggers) al destino apropiado.

  • Los filtros proporcionan una facilidad de ajuste preciso para determinar que registros generar.

  • Los formateadores especifican el diseño de los registros en el resultado final.

Objetos logger

Los loggers tienen los siguientes atributos y métodos. Tenga en cuenta que los loggers NUNCA deben ser instanciados directamente, siempre a través de la función de nivel de módulo logging.getLogger(name). Múltiples llamadas a getLogger() con el mismo nombre siempre retornarán una referencia al mismo objeto Logger.

The name is potentially a period-separated hierarchical value, like foo.bar.baz (though it could also be just plain foo, for example). Loggers that are further down in the hierarchical list are children of loggers higher up in the list. For example, given a logger with a name of foo, loggers with names of foo.bar, foo.bar.baz, and foo.bam are all descendants of foo. In addition, all loggers are descendants of the root logger. The logger name hierarchy is analogous to the Python package hierarchy, and identical to it if you organise your loggers on a per-module basis using the recommended construction logging.getLogger(__name__). That’s because in a module, __name__ is the module’s name in the Python package namespace.

class logging.Logger
name

This is the logger’s name, and is the value that was passed to getLogger() to obtain the logger.

Nota

This attribute should be treated as read-only.

level

The threshold of this logger, as set by the setLevel() method.

Nota

Do not set this attribute directly - always use setLevel(), which has checks for the level passed to it.

parent

The parent logger of this logger. It may change based on later instantiation of loggers which are higher up in the namespace hierarchy.

Nota

This value should be treated as read-only.

propagate

Si este atributo se evalúa como verdadero, los eventos registrados en este logger se pasarán a los gestores de los loggers de nivel superior (ancestro), además de los gestores asociados a este logger. Los mensajes se pasan directamente a los gestores de los loggers ancestrales; no se consideran ni el nivel ni los filtros de los loggers ancestrales en cuestión.

Si esto se evalúa como falso, los mensajes de registro no se pasan a los gestores de los logger ancestrales.

Explicándolo con un ejemplo: Si el atributo propagado del logger llamado A.B.C se evalúa a true, cualquier evento registrado en A.B.C a través de una llamada a un método como logging.getLogger('A.B.C').error(...) será [sujeto a pasar el nivel de ese logger y la configuración del filtro] pasado a su vez a cualquier manejador adjunto a los loggers llamados A.B, A y al logger raíz, después de ser pasado primero a cualquier manejador adjunto a A.B.C. Si cualquier logger en la cadena A.B.C, A.B, A tiene su atributo propagate a false, entonces ese es el último logger a cuyos manejadores se les ofrece el evento a manejar, y la propagación se detiene en ese punto.

El constructor establece este atributo en True.

Nota

Si adjunta un gestor a un logger y uno o más de sus ancestros, puede emitir el mismo registro varias veces. En general, no debería necesitar adjuntar un gestor a más de un logger; si solo lo adjunta al logger apropiado que está más arriba en la jerarquía del logger, verá todos los eventos registrados por todos los logger descendientes, siempre que la configuración de propagación sea True. Un escenario común es adjuntar gestores solo al logger raíz y dejar que la propagación se encargue del resto.

handlers

The list of handlers directly attached to this logger instance.

Nota

This attribute should be treated as read-only; it is normally changed via the addHandler() and removeHandler() methods, which use locks to ensure thread-safe operation.

disabled

This attribute disables handling of any events. It is set to False in the initializer, and only changed by logging configuration code.

Nota

This attribute should be treated as read-only.

setLevel(level)

Establece el umbral para este logger en level. Los mensajes de logging que son menos severos que level serán ignorados; los mensajes de logging que tengan un nivel de severidad level o superior serán emitidos por cualquier gestor o gestores que atiendan este logger, a menos que el nivel de un gestor haya sido configurado en un nivel de severidad más alto que level.

Cuando se crea un logger, el nivel se establece en NOTSET (que hace que todos los mensajes se procesen cuando el logger es el logger raíz, o la delegación al padre cuando el logger no es un logger raíz). Tenga en cuenta que el logger raíz se crea con el nivel WARNING.

El término “delegación al padre” significa que si un logger tiene un nivel de NOTSET, su cadena de logger ancestrales se atraviesa hasta que se encuentra un ancestro con un nivel diferente a NOTSET o se alcanza la raíz.

Si se encuentra un antepasado con un nivel distinto de NOTSET, entonces el nivel de ese antepasado se trata como el nivel efectivo del logger donde comenzó la búsqueda de antepasados, y se utiliza para determinar cómo se maneja un evento de registro.

Si se alcanza la raíz y tiene un nivel de NOTSET, se procesarán todos los mensajes. De lo contrario, el nivel de la raíz se utilizará como el nivel efectivo.

Ver Niveles de logging para obtener una lista de niveles.

Distinto en la versión 3.2: El parámetro level ahora acepta una representación de cadena del nivel como “INFO” como alternativa a las constantes de enteros como INFO. Sin embargo, tenga en cuenta que los niveles se almacenan internamente como e.j. getEffectiveLevel() y isEnabledFor() retornará/esperará que se pasen enteros.

isEnabledFor(level)

Indica si este logger procesará un mensaje de gravedad level. Este método verifica primero el nivel de nivel de módulo establecido por logging.disable(level) y luego el nivel efectivo del logger según lo determinado por getEffectiveLevel().

getEffectiveLevel()

Indica el nivel efectivo para este logger. Si se ha establecido un valor distinto de NOTSET utilizando setLevel(), se retorna. De lo contrario, la jerarquía se atraviesa hacia la raíz hasta que se encuentre un valor que no sea NOTSET y se retorna ese valor. El valor retornado es un entero, típicamente uno de logging.DEBUG, logging.INFO etc.

getChild(suffix)

Retorna un logger que es descendiente de este logger, según lo determinado por el sufijo. Por lo tanto, logging.getLogger('abc').getChild('def.ghi') retornaría el mismo logger que retornaría logging.getLogger('abc.def.ghi'). Este es un método convenientemente útil cuando el logger principal se nombra usando e.j. __name__ en lugar de una cadena literal.

Added in version 3.2.

getChildren()

Retorna un conjunto de loggers que son hijos inmediatos de este logger. Así, por ejemplo, logging.getLogger().getChildren() podría retornar un conjunto que contenga loggers llamados foo y bar, pero un logger llamado foo.bar no estaría incluido en el conjunto. Del mismo modo, logging.getLogger('foo').getChildren() podría retornar un conjunto que incluyera un logger llamado foo.bar, pero no incluiría uno llamado foo.bar.baz.

Added in version 3.12.

debug(msg, *args, **kwargs)

Registra un mensaje con el nivel DEBUG en este logger. El msg es la cadena de formato del mensaje, y los args son los argumentos que se fusionan en msg utilizando el operador de formato de cadena. (Tenga en cuenta que esto significa que puede usar palabras clave en la cadena de formato, junto con un solo argumento de diccionario). No se realiza ninguna operación de formateo mediante % en msg cuando no se proporcionan args.

Hay cuatro argumentos de palabras clave kwargs que se inspeccionan: exc_info, stack_info, stacklevel y extra.

Si exc_info no se evalúa como falso, hace que se agregue información de excepción al mensaje de registro. Si se proporciona una tupla de excepción (en el formato retornado por sys.exc_info()) o se proporciona una instancia de excepción, se utiliza; de lo contrario, se llama a sys.exc_info() para obtener la información de excepción.

El segundo argumento opcional con la palabra clave stack_info, que por defecto es False. Si es verdadero, la información de la pila agregara el mensaje de registro, incluida la actual llamada del registro. Tenga en cuenta que esta no es la misma información de la pila que se muestra al especificar exc_info: la primera son los cuadros de la pila desde la parte inferior de la pila hasta la llamada de registro en el hilo actual, mientras que la segunda es la información sobre los cuadros de la pila que se han desenrollado, siguiendo una excepción, mientras busca gestores de excepción.

Puede especificar stack_info independientemente de exc_info, por ejemplo solo para mostrar cómo llegaste a cierto punto en tu código, incluso cuando no se lanzaron excepciones. Los marcos de la pila se imprimen siguiendo una línea de encabezado que dice:

Stack (most recent call last):

Esto imita el Traceback (most recent call last): que se usa cuando se muestran marcos de excepción.

El tercer argumento opcional con la palabra clave stacklevel, que por defecto es 1. Si es mayor que 1, se omite el número correspondiente de cuadros de pila al calcular el número de línea y el nombre de la función establecidos en LogRecord creado para el evento de registro. Esto se puede utilizar en el registro de ayudantes para que el nombre de la función, el nombre de archivo y el número de línea registrados no sean la información para la función/método auxiliar, sino más bien su llamador. El nombre de este parámetro refleja el equivalente en el modulo warnings.

The fourth keyword argument is extra which can be used to pass a dictionary which is used to populate the __dict__ of the LogRecord created for the logging event with user-defined attributes. These custom attributes can then be used as you like. For example, they could be incorporated into logged messages. For example:

FORMAT = '%(asctime)s %(clientip)-15s %(user)-8s %(message)s'
logging.basicConfig(format=FORMAT)
d = {'clientip': '192.168.0.1', 'user': 'fbloggs'}
logger = logging.getLogger('tcpserver')
logger.warning('Protocol problem: %s', 'connection reset', extra=d)

imprimiría algo como

2006-02-08 22:20:02,165 192.168.0.1 fbloggs  Protocol problem: connection reset

Las claves en el diccionario pasado extra no deben entrar en conflicto con las claves utilizadas por el sistema de registro. (Ver la documentación de Atributos LogRecord para obtener más información sobre qué claves utiliza el sistema de registro).

Si elige usar estos atributos en los mensajes registrados, debe tener cuidado. En el ejemplo anterior, se ha configurado Formatter con una cadena de formato que espera clientip y “usuario” en el diccionario de atributos de LogRecord. Si faltan, el mensaje no se registrará porque se producirá una excepción de formato de cadena. En este caso, siempre debe pasar el diccionario extra con estas teclas.

Si bien esto puede ser molesto, esta función está diseñada para su uso en circunstancias especializadas, como servidores de subprocesos múltiples donde el mismo código se ejecuta en muchos contextos, y las condiciones interesantes que surgen dependen de este contexto (como la dirección IP del cliente remoto y autenticado nombre de usuario, en el ejemplo anterior). En tales circunstancias, es probable que se especialice Formatters con particular Handlers.

Si no hay ningún gestor asociado a este registrador (o cualquiera de sus antepasados, teniendo en cuenta los atributos relevantes Logger.propagate), el mensaje se enviará al gestor establecido en lastResort.

Distinto en la versión 3.2: Se agregó el parámetro stack_info.

Distinto en la versión 3.5: El parámetro exc_info ahora puede aceptar instancias de excepción.

Distinto en la versión 3.8: Se agregó el parámetro stacklevel.

info(msg, *args, **kwargs)

Registra un mensaje con el nivel INFO en este logger. Los argumentos se interpretan como debug().

warning(msg, *args, **kwargs)

Registra un mensaje con el nivel WARNING en este logger. Los argumentos se interpretan como debug().

Nota

Hay un método obsoleto warn que es funcionalmente idéntico a warning. Como warn está en desuso, no lo use, use warning en su lugar.

error(msg, *args, **kwargs)

Registra un mensaje con nivel ERROR en este logger. Los argumentos se interpretan como debug().

critical(msg, *args, **kwargs)

Registra un mensaje con el nivel CRITICAL en este logger. Los argumentos se interpretan como debug().

log(level, msg, *args, **kwargs)

Registra un mensaje con nivel entero level en este logger. Los otros argumentos se interpretan como debug().

exception(msg, *args, **kwargs)

Registra un mensaje con nivel ERROR en este logger. Los argumentos se interpretan como debug(). La información de excepción se agrega al mensaje de registro. Este método solo debe llamarse desde un gestor de excepciones.

addFilter(filter)

Agrega el filtro filter especificado a este logger.

removeFilter(filter)

Elimina el filtro filter especificado de este logger.

filter(record)

Aplique los filtros de este logger al registro y retorna True si se va a procesar el registro. Los filtros se consultan a su vez, hasta que uno de ellos retorna un valor falso. Si ninguno de ellos retorna un valor falso, el registro será procesado (pasado a los gestores). Si se retorna un valor falso, no se produce más procesamiento del registro.

addHandler(hdlr)

Agrega el gestor especificado hdlr a este logger.

removeHandler(hdlr)

Elimina el gestor especificado hdlr de este logger.

findCaller(stack_info=False, stacklevel=1)

Encuentra el nombre de archivo de origen de la invoca y el número de línea. Retorna el nombre del archivo, el número de línea, el nombre de la función y la información de la pila como una tupla de 4 elementos. La información de la pila se retorna como None a menos que stack_info sea True.

El parámetro stacklevel se pasa del código que llama a debug() y otras API. Si es mayor que 1, el exceso se utiliza para omitir los cuadros de la pila antes de determinar los valores que se retornarán. Esto generalmente será útil al llamar a las API de registro desde un helper/wrapper, de modo que la información en el registro de eventos no se refiera al helper/wrapper, sino al código que lo llama.

handle(record)

Gestiona un registro pasándolo a todos los gestores asociados con este logger y sus antepasados (hasta que se encuentre un valor falso de propagar). Este método se utiliza para registros no empaquetados recibidos de un socket, así como para aquellos creados localmente. El filtrado a nivel de logger se aplica usando filter().

makeRecord(name, level, fn, lno, msg, args, exc_info, func=None, extra=None, sinfo=None)

Este es un método factory que se puede sobreescribir en subclases para crear instancias especializadas LogRecord.

hasHandlers()

Comprueba si este logger tiene algún gestor configurado. Esto se hace buscando gestores en este logger y sus padres en la jerarquía del logger. Retorna True si se encontró un gestor, de lo contrario, False . El método deja de buscar en la jerarquía cada vez que se encuentra un logger con el atributo propagate establecido en falso: ese será el último logger que verificará la existencia de gestores.

Added in version 3.2.

Distinto en la versión 3.7: Los logger ahora se pueden serializar y deserializar (pickled and unpickled).

Niveles de logging

Los valores numéricos de los niveles de logging se dan en la siguiente tabla. Estos son principalmente de interés si desea definir sus propios niveles y necesita que tengan valores específicos en relación con los niveles predefinidos. Si define un nivel con el mismo valor numérico, sobrescribe el valor predefinido; se pierde el nombre predefinido.

Nivel

Valor numérico

Qué significa / Cuándo utilizarlo

logging.NOTSET

0

Cuando se establece en un logger, indica que los loggers antecesores deben ser consultados para determinar el nivel efectivo. Si el resultado sigue siendo NOTSET, se registrarán todos los eventos. Cuando se establece en un gestor, todos los eventos son gestionados.

logging.DEBUG

10

Información detallada, normalmente sólo de interés para un desarrollador que intenta diagnosticar un problema.

logging.INFO

20

Confirmación de que todo funciona según lo previsto.

logging.WARNING

30

Una indicación de que ha ocurrido algo inesperado o de que podría producirse un problema en un futuro próximo (por ejemplo, «espacio en disco bajo»). El software sigue funcionando como se esperaba.

logging.ERROR

40

Debido a un problema más grave, el software no ha podido realizar alguna función.

logging.CRITICAL

50

Un error grave, que indica que es posible que el propio programa no pueda seguir ejecutándose.

Gestor de objetos

Los gestores tienen los siguientes atributos y métodos. Tenga en cuenta que Handler nunca se instancia directamente; esta clase actúa como base para subclases más útiles. Sin embargo, el método __init__() en las subclases debe llamar a Handler.__init__().

class logging.Handler
__init__(level=NOTSET)

Inicializa la instancia Handler estableciendo su nivel, configurando la lista de filtros en la lista vacía y creando un bloqueo (usando createLock()) para serializar el acceso a un mecanismo de E/S.

createLock()

Inicializa un bloqueo de subprocesos que se puede utilizar para serializar el acceso a la funcionalidad de E/S subyacente que puede no ser segura para subprocesos.

acquire()

Adquiere el bloqueo de hilo creado con createLock().

release()

Libera el bloqueo de hilo adquirido con acquire().

setLevel(level)

Establece el umbral para este gestor en level. Los mensajes de registro que son menos severos que level serán ignorados. Cuando se crea un gestor, el nivel se establece en NOTSET (lo que hace que se procesen todos los mensajes).

Ver Niveles de logging para obtener una lista de niveles.

Distinto en la versión 3.2: El parámetro level ahora acepta una representación de cadena del nivel como “INFO” como alternativa a las constantes de enteros como INFO.

setFormatter(fmt)

Establece Formatter para este gestor en fmt.

addFilter(filter)

Agrega el filtro filter especificado a este gestor.

removeFilter(filter)

Elimina el filtro especificado filter de este gestor.

filter(record)

Aplique los filtros de este gestor al registro y retorna True si se va a procesar el registro. Los filtros se consultan a su vez, hasta que uno de ellos retorna un valor falso. Si ninguno de ellos retorna un valor falso, se emitirá el registro. Si uno retorna un valor falso, el gestor no emitirá el registro.

flush()

Asegúrese de que toda la salida de logging se haya vaciado. Esta versión no hace nada y está destinada a ser implementada por subclases.

close()

Poner en orden los recursos utilizados por el gestor. Esta versión no genera salida, pero elimina el gestor de una lista interna de gestores que se cierra cuando se llama a shutdown(). Las subclases deben garantizar que esto se llame desde métodos close() sobreescritos.

handle(record)

Emite condicionalmente el registro especifico, según los filtros que se hayan agregado al gestor. Envuelve la actual emisión del registro con acquisition/release del hilo de bloqueo E/S.

handleError(record)

This method should be called from handlers when an exception is encountered during an emit() call. If the module-level attribute raiseExceptions is False, exceptions get silently ignored. This is what is mostly wanted for a logging system - most users will not care about errors in the logging system, they are more interested in application errors. You could, however, replace this with a custom handler if you wish. The specified record is the one which was being processed when the exception occurred. (The default value of raiseExceptions is True, as that is more useful during development).

format(record)

Formato para un registro - si se configura un formateador, úselo. De lo contrario, use el formateador predeterminado para el módulo.

emit(record)

Haga lo que sea necesario para registrar de forma especifica el registro. Esta versión está destinada a ser implementada por subclases y, por lo tanto, lanza un NotImplementedError.

Advertencia

Este método es llamado después de que un bloqueo a nivel de gestor es adquirido, el cual es liberado después de que este método retorna. Cuando sobrescriba este método, tenga en cuenta que debe tener cuidado al llamar a cualquier cosa que invoque a otras partes de la API de registro que puedan realizar bloqueos, ya que esto podría provocar un bloqueo. Específicamente:

  • Las API de configuración del registro adquieren el bloqueo a nivel de módulo y, a continuación, los bloqueos a nivel de gestor individual a medida que se configuran dichos gestores.

  • Muchas APIs de registro bloquean el bloqueo a nivel de módulo. Si se llama a una API de este tipo desde este método, podría causar un bloqueo si se realiza una llamada de configuración en otro hilo, porque ese hilo intentará adquirir el bloqueo a nivel de módulo antes del bloqueo a nivel de gestor, mientras que este hilo intenta adquirir el bloqueo a nivel de módulo después del bloqueo a nivel de gestor (porque en este método, el bloqueo a nivel de gestor ya se ha adquirido).

Para obtener una lista de gestores incluidos como estándar, consulte logging.handlers.

Objetos formateadores

class logging.Formatter(fmt=None, datefmt=None, style='%', validate=True, *, defaults=None)

Responsable de convertir un LogRecord en una cadena de salida para ser interpretada por un humano o un sistema externo.

Parámetros:
  • fmt (str) – Una cadena de formato en el estilo dado para la salida registrada en su conjunto. Las posibles claves de mapeo se extraen de Atributos LogRecord del objeto LogRecord. Si no se especifica, se utiliza '%(message)s', que es sólo el mensaje registrado.

  • datefmt (str) – Una cadena de formato en el estilo dado para la parte de fecha/hora de la salida registrada. Si no se especifica, se utiliza el valor predeterminado descrito en formatTime().

  • style (str) – El parámetro style puede ser '%', '{' o '$' y determina cómo se fusionará la cadena de formato con sus datos: usando Formateo de cadenas al estilo *printf* (%), str.format() ({) o string.Template ($). Esto solo aplica al formato de cadenas de caracteres fmt y datefmt (e.j. '%(message)s' o '{message}'), no al mensaje de registro real pasado a los métodos de logging. Sin embargo, hay other ways para usar { y $ en el formateo de mensajes de registro.

  • validate (bool) – Si el parámetro validate es True (lo es por defecto), es incorrecto o no coincidente, fmt y style lanzarán un ValueError; Por ejemplo, logging.Formatter('%(asctime)s - %(message)s', style='{').

  • defaults (dict[str, Any]) – El parámetro defaults puede ser un diccionario con valores por defecto para usar en campos personalizados. Por ejemplo: logging.Formatter('%(ip)s %(message)s', defaults={"ip": None})

Distinto en la versión 3.2: Added the style parameter.

Distinto en la versión 3.8: Added the validate parameter.

Distinto en la versión 3.10: Added the defaults parameter.

format(record)

El diccionario de atributos del registro se usa como el operando de una operación para formateo de cadenas. Retorna la cadena resultante. Antes de formatear el diccionario, se lleva a cabo un par de pasos preparatorios. El atributo message del registro se calcula usando msg % args. Si el formato de la cadena contiene '(asctime)', formatTime() se llama para dar formato al tiempo del evento. Si hay información sobre la excepción, se formatea usando formatException() y se adjunta al mensaje. Tenga en cuenta que la información de excepción formateada se almacena en caché en el atributo exc_text. Esto es útil porque la información de excepción se puede serializar con pickle (pickled) y propagarse por el cable, pero debe tener cuidado si tiene más de una subclase de Formatter que personaliza el formato de la información de la excepción. En este caso, tendrá que borrar el valor almacenado en caché (estableciendo el atributo exc_text a None) después de que un formateador haya terminado su formateo, para que el siguiente formateador que maneje el evento no use el valor almacenado en caché, sino que lo recalcule de nuevo.

Si la información de la pila está disponible, se agrega después de la información de la excepción, usando formatStack() para transformarla si es necesario.

formatTime(record, datefmt=None)

Este método debe ser llamado desde format() por un formateador que espera un tiempo formateado . Este método se puede reemplazar en formateadores para proporcionar cualquier requisito específico, pero el comportamiento básico es el siguiente: if datefmt (una cadena), se usa con time.strftime() para formatear el tiempo de creación del registro De lo contrario, se utiliza el formato “%Y-%m-%d %H:%M:%S,uuu”, donde la parte uuu es un valor de milisegundos y las otras letras son time.strftime() . Un ejemplo de tiempo en este formato es 2003-01-23 00:29:50,411. Se retorna la cadena resultante.

Esta función utiliza una función configurable por el usuario para convertir el tiempo de creación en una tupla. Por defecto, se utiliza time.localtime(); Para cambiar esto para una instancia de formateador particular, se agrega el atributo converter en una función con igual firma como time.localtime() o time.gmtime(). Para cambiarlo en todos los formateadores, por ejemplo, si desea que todos los tiempos de registro se muestren en GMT, agregue el atributo converter en la clase Formatter.

Distinto en la versión 3.3: Anteriormente, el formato predeterminado estaba codificado como en este ejemplo: 2010-09-06 22:38:15,292 donde la parte anterior a la coma es manejada por una cadena de formato strptime ('%Y-%m-%d %H:%M:%S'), y la parte después de la coma es un valor de milisegundos. Debido a que strptime no tiene una posición de formato para milisegundos, el valor de milisegundos se agrega usando otra cadena de formato, '%s,%03d'— ambas cadenas de formato se han codificado en este método. Con el cambio, estas cadenas se definen como atributos de nivel de clase que pueden overridden a nivel de instancia cuando se desee. Los nombres de los atributos son default_time_format (para una cadena de formato strptime) y default_msec_format (para agregar el valor de milisegundos).

Distinto en la versión 3.9: El formato default_msec_format puede ser None.

formatException(exc_info)

Formatea la información de una excepción especificada (una excepción como una tupla estándar es retornada por sys.exc_info()) como una cadena. Esta implementación predeterminada solo usa traceback.print_exception(). La cadena resultantes retornada.

formatStack(stack_info)

Formatea la información de una pila especificada (una cadena es retornada por traceback.print_stack(), pero con la ultima línea removida) como una cadena. Esta implementación predeterminada solo retorna el valor de entrada.

class logging.BufferingFormatter(linefmt=None)

Una clase base de formateador adecuada para subclasificar cuando se desea formatear un número de registros. Puede pasar una instancia Formatter que desee utilizar para formatear cada línea (que corresponde a un único registro). Si no se especifica, el formateador por defecto (que sólo muestra el mensaje del evento) se utiliza como formateador de línea.

formatHeader(records)

Retorna una cabecera para una lista de registros. La implementación base sólo retorna la cadena vacía. Tendrá que anular este método si desea un comportamiento específico, por ejemplo, mostrar el recuento de registros, un título o una línea separadora.

formatFooter(records)

Retorna un pie de página para una lista de registros. La implementación base sólo retorna la cadena vacía. Tendrá que anular este método si desea un comportamiento específico, por ejemplo, para mostrar el recuento de registros o una línea separadora.

format(records)

Retorna el texto formateado de una lista de registros. La implementación base sólo retorna la cadena vacía si no hay registros; en caso contrario, retorna la concatenación de la cabecera, cada registro formateado con el formateador de líneas y el pie de página.

Filtro de Objetos

Los Manejadores y los Registradores pueden usar los Filtros para un filtrado más sofisticado que el proporcionado por los niveles. La clase de filtro base solo permite eventos que están por debajo de cierto punto en la jerarquía del logger. Por ejemplo, un filtro inicializado con “A.B” permitirá los eventos registrados por los logger “A.B”, “A.B.C”, “A.B.C.D”, “A.B.D” etc., pero no “A.BB”, “B.A.B”, etc. Si se inicializa con una cadena vacía, se pasan todos los eventos.

class logging.Filter(name='')

Retorna una instancia de la clase Filter. Si se especifica name, nombra un logger que, junto con sus hijos, tendrá sus eventos permitidos a través del filtro. Si name es una cadena vacía, permite todos los eventos.

filter(record)

¿Debe registrarse el registro especificado? Retorna “false” para no, “true” para sí. Los filtros pueden modificar los registros en el lugar o retornar una instancia de registro completamente diferente que sustituirá al registro original en cualquier procesamiento futuro del evento.

Tenga en cuenta que los filtros adjuntos a los gestores se consultan antes de que el gestor emita un evento, mientras que los filtros adjuntos a los loggers se consultan cada vez que se registra un evento (usando debug(), info(), etc.), antes de enviar un evento a los gestores. Esto significa que los eventos que han sido generados por loggers descendientes no serán filtrados por la configuración del filtro del logger, a menos que el filtro también se haya aplicado a esos loggers descendientes.

En realidad, no se necesita la subclase Filtro: se puede pasar cualquier instancia que tenga un método de filter con la misma semántica.

Distinto en la versión 3.2: No es necesario crear clases especializadas de Filter ni usar otras clases con un método filter: puede usar una función (u otra invocable) como filtro. La lógica de filtrado verificará si el objeto de filtro tiene un atributo filter: si lo tiene, se asume que es un Filter y se llama a su método filter(). De lo contrario, se supone que es invocable y se llama con el registro como único parámetro. El valor retornado debe ajustarse al retornado por filter().

Distinto en la versión 3.12: Ahora puedes retornar una instancia de LogRecord desde los filtros para reemplazar el registro en lugar de modificarlo. Esto permite a los filtros adjuntos a un Handler modificar el registro de log antes de que se emita, sin tener efectos secundarios en otros gestores.

Aunque los filtros se utilizan principalmente para filtrar registros basados en criterios más sofisticados que los niveles, son capaces de ver cada registro que es procesado por el gestor o logger al que están adjuntos: esto puede ser útil si desea hacer cosas como contar cuántos registros fueron procesados por un logger o gestor en particular, o agregando, cambiando o quitando atributos en LogRecord que se está procesando. Obviamente, el cambio de LogRecord debe hacerse con cierto cuidado, pero permite la inyección de información contextual en los registros (ver Usar filtros para impartir información contextual).

Objetos LogRecord

Las instancias LogRecord son creadas automáticamente por Logger cada vez que se registra algo, y se pueden crear manualmente a través de makeLogRecord() (por ejemplo, a partir de un evento serializado (pickled) recibido en la transmisión).

class logging.LogRecord(name, level, pathname, lineno, msg, args, exc_info, func=None, sinfo=None)

Contiene toda la información pertinente al evento que se registra.

La información principal se pasa en msg y args, que se combinan usando msg % args para crear el atributo message del registro.

Parámetros:
  • name (str) – El nombre del logger utilizado para registrar el evento representado por este LogRecord. Tenga en cuenta que el nombre del logger en el LogRecord siempre tendrá este valor, aunque puede ser emitido por un gestor adjunto a un logger diferente (ancestro).

  • level (int) – El numeric level del evento de registro (como 10 para DEBUG, 20 para INFO, etc). Tenga en cuenta que esto se convierte en dos atributos del LogRecord: levelno para el valor numérico y levelname para el nombre del nivel correspondiente.

  • pathname (str) – El nombre de ruta completo del archivo de origen donde se realizó la llamada logging.

  • lineno (int) – El número de línea en el archivo de origen donde se realizó la llamada logging.

  • msg (Any) – El mensaje de descripción del evento, que puede ser una cadena de formato %, con marcadores de posición para datos variables o un objeto arbitrario (para más información vea Usando objetos arbitrarios como mensajes).

  • args (tuple | dict[str, Any]) – Datos variables para fusionar en el argumento msg para obtener la descripción del evento.

  • exc_info (tuple[type[BaseException], BaseException, types.TracebackType] | None) – Una tupla de excepción con la información de excepción actual, tal como se retorna por sys.exc_info() o None si no hay información de excepción disponible.

  • func (str | None) – El nombre de la función o método desde el que se invocó la llamada de logging.

  • sinfo (str | None) – Una cadena de texto que representa la información de la pila desde la base de la pila en el hilo actual, hasta la llamada de logging.

getMessage()

Retorna el mensaje para la instancia LogRecord después de fusionar cualquier argumento proporcionado por el usuario con el mensaje. Si el argumento del mensaje proporcionado por el usuario para la llamada de logging no es una cadena de caracteres, se invoca str() para convertirlo en una cadena. Esto permite el uso de clases definidas por el usuario como mensajes, cuyo método __str__ puede retornar la cadena de formato real que se utilizará.

Distinto en la versión 3.2: La creación de LogRecord se ha hecho más configurable al proporcionar una fábrica que se utiliza para crear el registro. La fábrica se puede configurar usando getLogRecordFactory() y setLogRecordFactory() (ver esto para la firma de la fábrica).

Esta funcionalidad se puede utilizar para inyectar sus propios valores en LogRecord en el momento de la creación. Puede utilizar el siguiente patrón:

old_factory = logging.getLogRecordFactory()

def record_factory(*args, **kwargs):
    record = old_factory(*args, **kwargs)
    record.custom_attribute = 0xdecafbad
    return record

logging.setLogRecordFactory(record_factory)

Con este patrón, se podrían encadenar varias fábricas y, siempre que no sobrescriban los atributos de las demás o se sobrescriban involuntariamente los atributos estándar enumerados anteriormente, no debería haber sorpresas.

Atributos LogRecord

El LogRecord tiene una serie de atributos, la mayoría de los cuales se derivan de los parámetros del constructor. (Tenga en cuenta que los nombres no siempre se corresponden exactamente entre los parámetros del constructor de LogRecord y los atributos de LogRecord). Estos atributos pueden utilizarse para combinar los datos del registro en la cadena de formato. La siguiente tabla enumera (en orden alfabético) los nombres de los atributos, sus significados y el correspondiente marcador de posición en una cadena de formato %-style.

Si utilizas formato-{} (str.format()), puedes usar {attrname} como marcador de posición en la cadena de caracteres de formato. Si está utilizando formato-$ (string.Template), use la forma ${attrname}. En ambos casos, por supuesto, reemplace attrname con el nombre de atributo real que desea utilizar.

En el caso del formato con {}, puede especificar flags de formato colocándolos después del nombre del atributo, separados con dos puntos. Por ejemplo: un marcador de posición de {msecs:03.0f} formateará un valor de milisegundos de 4 como 004. Consulte la documentación str.format() para obtener detalles completos sobre las opciones disponibles.

Nombre del atributo

Formato

Descripción

args

No debería necesitar formatear esto usted mismo.

La tupla de argumentos se fusionó en msg para producir un messsage, o un dict cuyos valores se utilizan para la fusión (cuando solo hay un argumento y es un diccionario).

asctime

%(asctime)s

Fecha y Hora en formato legible por humanos cuando se creó LogRecord. De forma predeterminada, tiene el formato “2003-07-08 16: 49: 45,896” (los números después de la coma son milisegundos).

created

%(created)f

Time when the LogRecord was created (as returned by time.time_ns() / 1e9).

exc_info

No debería necesitar formatear esto usted mismo.

Tupla de excepción (al modo sys.exc_info) o, si no se ha producido ninguna excepción, None.

filename

%(filename)s

Parte del nombre de archivo de pathname.

funcName

%(funcName)s

Nombre de la función que contiene la llamada de logging.

levelname

%(levelname)s

Texto de nivel de logging para el mensaje ('DEBUG', 'INFO', 'WARNING', 'ERROR', 'CRITICAL').

levelno

%(levelno)s

Número de nivel de logging para el mensaje (DEBUG, INFO, WARNING, ERROR, CRITICAL).

lineno

%(lineno)d

Número de línea original donde se emitió la llamada de logging (si está disponible).

message

%(message)s

El mensaje registrado, computado como msg % args. Esto se establece cuando se invoca Formatter.format().

module

%(module)s

Módulo (parte del nombre de filename).

msecs

%(msecs)d

Porción de milisegundos del tiempo en que se creó LogRecord.

msg

No debería necesitar formatear esto usted mismo.

La cadena de caracteres de formato pasada en la llamada logging original. Se fusionó con args para producir un message, o un objeto arbitrario (ver Usando objetos arbitrarios como mensajes).

name

%(name)s

Nombre del logger usado para registrar la llamada.

pathname

%(pathname)s

Nombre de ruta completo del archivo de origen donde se emitió la llamada de logging (si está disponible).

process

%(process)d

ID de proceso (si está disponible).

processName

%(processName)s

Nombre del proceso (si está disponible).

relativeCreated

%(relativeCreated)d

Tiempo en milisegundos cuando se creó el LogRecord, en relación con el tiempo en que se cargó el módulo logging.

stack_info

No debería necesitar formatear esto usted mismo.

Apila la información del marco (si está disponible) desde la parte inferior de la pila en el hilo actual hasta la llamada de registro que dio como resultado la generación de este registro.

thread

%(thread)d

ID de hilo (si está disponible).

threadName

%(threadName)s

Nombre del hilo (si está disponible).

taskName

%(taskName)s

nombre de asyncio.Task (si está disponible).

Distinto en la versión 3.1: processName fue agregado.

Distinto en la versión 3.12: taskName fue agregado.

Objetos LoggerAdapter

Las instancias LoggerAdapter se utilizan para pasar convenientemente información contextual en las llamadas de logging. Para ver un ejemplo de uso, consulte la sección sobre agregar información contextual a su salida de logging.

class logging.LoggerAdapter(logger, extra, merge_extra=False)

Returns an instance of LoggerAdapter initialized with an underlying Logger instance, a dict-like object (extra), and a boolean (merge_extra) indicating whether or not the extra argument of individual log calls should be merged with the LoggerAdapter extra. The default behavior is to ignore the extra argument of individual log calls and only use the one of the LoggerAdapter instance

process(msg, kwargs)

Modifica el mensaje y/o los argumentos de palabra clave pasados a una llamada de logging para insertar información contextual. Esta implementación toma el objeto pasado como extra al constructor y lo agrega a kwargs usando la clave “extra”. El valor de retorno es una tupla (msg, kwargs) que tiene las versiones (posiblemente modificadas) de los argumentos pasados.

manager

Delegates to the underlying manager on logger.

_log

Delegates to the underlying _log() method on logger.

Además de lo anterior, LoggerAdapter admite los siguientes métodos de Logger: debug(), info(), warning(), error(), exception(), critical(), log(), isEnabledFor(), getEffectiveLevel(), setLevel() y hasHandlers(). Estos métodos tienen las mismas firmas que sus contrapartes en Logger, por lo que puede usar los dos tipos de instancias indistintamente.

Distinto en la versión 3.2: Los métodos isEnabledFor(), getEffectiveLevel(), setLevel() y hasHandlers() se agregaron a LoggerAdapter . Estos métodos se delegan al logger subyacente.

Distinto en la versión 3.6: Se añadió el atributo manager y el método _log(), que delegan al logger subyacente y permiten que los adaptadores se aniden.

Distinto en la versión 3.13: The merge_extra argument was added.

Seguridad del hilo

El módulo logging está diseñado para ser seguro para subprocesos sin que sus clientes tengan que realizar ningún trabajo especial. Lo logra mediante el uso de bloqueos de hilos; hay un bloqueo para serializar el acceso a los datos compartidos del módulo, y cada gestor también crea un bloqueo para serializar el acceso a su E/S subyacente.

Si está implementando gestores de señales asíncronos usando el módulo signal, es posible que no pueda usar logging desde dichos gestores. Esto se debe a que las implementaciones de bloqueo en el módulo threading no siempre son reentrantes y, por lo tanto, no se pueden invocar desde dichos gestores de señales.

Funciones a nivel de módulo

Además de las clases descritas anteriormente, hay una serie de funciones a nivel de módulo.

logging.getLogger(name=None)

Return a logger with the specified name or, if name is None, return the root logger of the hierarchy. If specified, the name is typically a dot-separated hierarchical name like “a”, “a.b” or “a.b.c.d”. Choice of these names is entirely up to the developer who is using logging, though it is recommended that __name__ be used unless you have a specific reason for not doing that, as mentioned in Objetos logger.

Todas las llamadas a esta función con un nombre dado retornan la misma instancia de logger. Esto significa que las instancias del logger nunca necesitan pasar entre diferentes partes de una aplicación.

logging.getLoggerClass()

Retorna ya sea la clase estándar Logger, o la última clase pasada a setLoggerClass(). Esta función se puede llamar desde una nueva definición de clase, para garantizar que la instalación de una clase personalizada Logger no deshaga las customizaciones ya aplicadas por otro código. Por ejemplo:

class MyLogger(logging.getLoggerClass()):
    # ... override behaviour here
logging.getLogRecordFactory()

Retorna un invocable que se usa para crear una LogRecord.

Added in version 3.2: Esta función se ha proporcionado, junto con setLogRecordFactory(), para permitir a los desarrolladores un mayor control sobre cómo LogRecord representa un evento logging construido.

Consulte setLogRecordFactory() para obtener más información sobre cómo se llama a la fábrica.

logging.debug(msg, *args, **kwargs)

This is a convenience function that calls Logger.debug(), on the root logger. The handling of the arguments is in every way identical to what is described in that method.

The only difference is that if the root logger has no handlers, then basicConfig() is called, prior to calling debug on the root logger.

For very short scripts or quick demonstrations of logging facilities, debug and the other module-level functions may be convenient. However, most programs will want to carefully and explicitly control the logging configuration, and should therefore prefer creating a module-level logger and calling Logger.debug() (or other level-specific methods) on it, as described at the beginning of this documentation.

logging.info(msg, *args, **kwargs)

Logs a message with level INFO on the root logger. The arguments and behavior are otherwise the same as for debug().

logging.warning(msg, *args, **kwargs)

Logs a message with level WARNING on the root logger. The arguments and behavior are otherwise the same as for debug().

Nota

Hay una función obsoleta warn que es funcionalmente idéntica a warning. Como warn está deprecado, por favor no lo use, use warning en su lugar.

logging.error(msg, *args, **kwargs)

Logs a message with level ERROR on the root logger. The arguments and behavior are otherwise the same as for debug().

logging.critical(msg, *args, **kwargs)

Logs a message with level CRITICAL on the root logger. The arguments and behavior are otherwise the same as for debug().

logging.exception(msg, *args, **kwargs)

Logs a message with level ERROR on the root logger. The arguments and behavior are otherwise the same as for debug(). Exception info is added to the logging message. This function should only be called from an exception handler.

logging.log(level, msg, *args, **kwargs)

Logs a message with level level on the root logger. The arguments and behavior are otherwise the same as for debug().

logging.disable(level=CRITICAL)

Proporciona un nivel superior de level para todos los loggers que tienen prioridad sobre el propio nivel del logger. Cuando surge la necesidad de reducir temporalmente la salida de logging en toda la aplicación, esta función puede resultar útil. Su efecto es deshabilitar todas las llamadas de gravedad level e inferior, de modo que si lo llaman con un valor de INFO, todos los eventos INFO y DEBUG se descartarán, mientras que los de gravedad WARNING y superiores se procesarán de acuerdo con el nivel efectivo del logger. Si se llama a logging.disable(logging.NOTSET) , elimina efectivamente este nivel primordial, de modo que la salida del registro depende nuevamente de los niveles efectivos de los loggers individuales.

Tenga en cuenta que si ha definido un nivel de logging personalizado superior a CRITICAL (esto no es recomendado), no podrá confiar en el valor predeterminado para el parámetro level, pero tendrá que proporcionar explícitamente un valor adecuado.

Distinto en la versión 3.7: El parámetro level se estableció por defecto en el nivel CRITICAL. Consulte el Issue #28524 para obtener más información sobre este cambio.

logging.addLevelName(level, levelName)

Asocia nivel level con el texto levelName en un diccionario interno, que se utiliza para asignar niveles numéricos a una representación textual, por ejemplo, cuando Formatter formatea un mensaje. Esta función también se puede utilizar para definir sus propios niveles. Las únicas restricciones son que todos los niveles utilizados deben registrarse utilizando esta función, los niveles deben ser números enteros positivos y deben aumentar en orden creciente de severidad.

Nota

Si está pensando en definir sus propios niveles, consulte la sección sobre Niveles personalizados.

logging.getLevelNamesMapping()

Retorna una correspondencia entre los nombres de nivel y sus correspondientes niveles de registro. Por ejemplo, la cadena «CRITICAL» corresponde a CRITICAL. La correspondencia retornada se copia de una correspondencia interna en cada llamada a esta función.

Added in version 3.11.

logging.getLevelName(level)

Retorna la representación textual o numérica del nivel de registro level.

Si level es uno de los niveles predefinidos CRITICAL, ERROR, WARNING, INFO o DEBUG entonces se obtiene la cadena correspondiente. Si has asociado niveles con nombres usando addLevelName() entonces se retorna el nombre que has asociado con level. Si se pasa un valor numérico correspondiente a uno de los niveles definidos, se retorna la representación de cadena correspondiente.

El parámetro level también acepta una representación de cadena del nivel como, por ejemplo, «INFO». En estos casos, esta función retorna el correspondiente valor numérico del nivel.

Si no se pasa un valor numérico o de cadena que coincida, se retorna el valor de nivel de la cadena “Level %s”.

Nota

Los niveles internamente son números enteros (ya que deben compararse en la lógica de logging). Esta función se utiliza para convertir entre un nivel entero y el nombre del nivel que se muestra en la salida de logging formateado mediante el especificador de formato %(levelname)s (ver Atributos LogRecord).

Distinto en la versión 3.4: En las versiones de Python anteriores a la 3.4, esta función también podría pasar un nivel de texto y retornaría el valor numérico correspondiente del nivel. Este comportamiento indocumentado se consideró un error y se eliminó en Python 3.4, pero se restableció en 3.4.2 debido a que conserva la compatibilidad con versiones anteriores.

logging.getHandlerByName(name)

Retorna un gestor con el name especificado o None si no hay un gestor con ese nombre.

Added in version 3.12.

logging.getHandlerNames()

Retorna un conjunto inmutable del nombre de todos los gestor conocidos.

Added in version 3.12.

logging.makeLogRecord(attrdict)

Crea y retorna una nueva instancia LogRecord cuyos atributos están definidos por attrdict. Esta función es útil para tomar un diccionario de atributos serializado (pickled) LogRecord, enviado a través de un socket, y reconstituido como una instancia LogRecord en el extremo receptor.

logging.basicConfig(**kwargs)

Realiza una configuración básica para el sistema de logging creando una StreamHandler con un Formatter predeterminado y agregándolo al logger raíz. Las funciones debug(), info(), warning(), error() y critical() llamarán basicConfig() automáticamente si no se definen gestores para el logger raíz.

Esta función no hace nada si el logger raíz ya tiene gestores configurados, a menos que el argumento de palabra clave force esté establecido como True.

Nota

Esta función debe llamarse desde el hilo principal antes de que se inicien otros hilos. En las versiones de Python anteriores a 2.7.1 y 3.2, si se llama a esta función desde varios subprocesos, es posible (en raras circunstancias) que se agregue un gestor al logger raíz más de una vez, lo que genera resultados inesperados como mensajes duplicados en el registro.

Se admiten los siguientes argumentos de palabras clave.

Formato

Descripción

filename

Especifica que se cree un FileHandler, utilizando el nombre de archivo especificado, en lugar de StreamHandler.

filemode

Si se especifica filename, abre el archivo en mode. Por defecto es 'a'.

format

Utiliza la cadena de caracteres de formato especificada para el gestor.Los atributos por defecto son levelname, name y message separado por dos puntos.

datefmt

Utiliza el formato de fecha/hora especificado, aceptado por time.strftime().

style

Si format es especificado, utilice este estilo para la cadena de caracteres de formato. Uno de '%', '{' o '$' para printf-style, str.format() o string.Template respectivamente. El valor predeterminado es '%'.

level

Establece el nivel del logger raíz en el level especificado.

stream

Utiliza la secuencia especificada para inicializar StreamHandler. Tenga en cuenta que este argumento es incompatible con filename - si ambos están presentes, se lanza un ValueError.

handlers

Si se especifica, debe ser una iteración de los gestores ya creados para agregar al logger raíz. A cualquier gestor que aún no tenga un formateador configurado se le asignará el formateador predeterminado creado en esta función. Tenga en cuenta que este argumento es incompatible con filename o stream; si ambos están presentes, se lanza un ValueError.

force

Si este argumento de palabra clave se especifica como verdadero, los gestores existentes adjuntos al logger raíz se eliminan y cierran antes de llevar a cabo la configuración tal como se especifica en los otros argumentos.

encoding

Si este argumento de palabra clave se especifica junto con filename, su valor se utiliza cuando se crea el FileHandler, y por lo tanto se utiliza al abrir el archivo de salida.

errors

Si este argumento de palabra clave se especifica junto con filename, su valor se utiliza cuando se crea el FileHandler, y por lo tanto cuando se abre el archivo de salida. Si no se especifica, se utiliza el valor “backslashreplace”. Tenga en cuenta que si se especifica None, se pasará como tal a open(), lo que significa que se tratará igual que pasar “errors”.

Distinto en la versión 3.2: Se agregó el argumento style.

Distinto en la versión 3.3: Se agregó el argumento handlers. Se agregaron verificaciones adicionales para detectar situaciones en las que se especifican argumentos incompatibles (por ejemplo, handlers junto con stream o filename, o stream junto con filename).

Distinto en la versión 3.8: Se agregó el argumento force.

Distinto en la versión 3.9: Se han añadido los argumentos encoding y errors.

logging.shutdown()

Informa al sistema de logging para realizar un apagado ordenado descargando y cerrando todos los gestores. Esto se debe llamar al salir de la aplicación y no se debe hacer ningún uso posterior del sistema de logging después de esta llamada.

Cuando se importa el módulo de logging, registra esta función como un gestor de salida (ver atexit), por lo que normalmente no es necesario hacerlo manualmente.

logging.setLoggerClass(klass)

Le dice al sistema de logging que use la clase klass al crear una instancia de un logger. La clase debe definir __init__() tal que solo se requiera un argumento de nombre, y __init__() debe llamar Logger.__init__(). Por lo general, esta función se llama antes de que cualquier logger sea instanciado por las aplicaciones que necesitan utilizar un comportamiento de logger personalizado. Después de esta llamada, como en cualquier otro momento, no cree instancias de loggers directamente usando la subclase: continúe usando la API logging.getLogger() para obtener sus loggers.

logging.setLogRecordFactory(factory)

Establece un invocable que se utiliza para crear LogRecord.

Parámetros:

factory – La fábrica invocable que se utilizará para crear una instancia de un registro.

Added in version 3.2: Esta función se ha proporcionado, junto con getLogRecordFactory(), para permitir a los desarrolladores un mayor control sobre cómo se construye LogRecord que representa un evento de logging.

La fábrica tiene la siguiente firma:

factory(name, level, fn, lno, msg, args, exc_info, func=None, sinfo=None, **kwargs)

name:

El nombre del logger.

level:

El nivel de logging (numérico).

fn:

El nombre de ruta completo del archivo donde se realizó la llamada de logging.

lno:

El número de línea en el archivo donde se realizó la llamada de logging.

msg:

El mensaje de logging.

args:

Los argumentos para el mensaje de logging.

exc_info:

Una tupla de excepción o None.

func:

El nombre de la función o método que invocó la llamada de logging.

sinfo:

Un seguimiento de pila como el que proporciona traceback.print_stack(), que muestra la jerarquía de llamadas.

kwargs:

Argumentos de palabras clave adicionales.

Atributos a nivel de módulo

logging.lastResort

Un «gestor de último recurso» está disponible a través de este atributo. Esta es una StreamHandler que escribe en sys.stderr con un nivel WARNING, y se usa para gestionar eventos de logging en ausencia de cualquier configuración de logging. El resultado final es simplemente imprimir el mensaje en sys.stderr. Esto reemplaza el mensaje de error anterior que decía que «no se pudieron encontrar gestores para el logger XYZ». Si necesita el comportamiento anterior por alguna razón, lastResort se puede configurar en None.

Added in version 3.2.

logging.raiseExceptions

Used to see if exceptions during handling should be propagated.

Default: True.

If raiseExceptions is False, exceptions get silently ignored. This is what is mostly wanted for a logging system - most users will not care about errors in the logging system, they are more interested in application errors.

Integración con el módulo de advertencias

La función captureWarnings() se puede utilizar para integrar logging con el módulo warnings.

logging.captureWarnings(capture)

Esta función se utiliza para activar y desactivar la captura de advertencias (warnings).

Si capture es True, las advertencias emitidas por el módulo warnings serán redirigidas al sistema de logging. Específicamente, una advertencia se formateará usando warnings.formatwarning() y la cadena de caracteres resultante se registrará en un logger llamado 'py.warnings' con severidad WARNING.

Si capture es False, la redirección de advertencias al sistema de logging se detendrá y las advertencias serán redirigidas a sus destinos originales (es decir, aquellos en vigor antes de que se llamara a captureWarnings(True)).

Ver también

Módulo logging.config

API de configuración para el módulo logging.

Módulo logging.handlers

Gestores útiles incluidos con el módulo logging.

PEP 282 - A Logging System

La propuesta que describió esta característica para su inclusión en la biblioteca estándar de Python.

Paquete logging original de Python

Esta es la fuente original del paquete logging. La versión del paquete disponible en este sitio es adecuada para usar con Python 1.5.2, 2.1.xy 2.2.x, que no incluyen el paquete logging en la biblioteca estándar.