Le module de journalisation de Python fournit un système de journalisation général, qui peut être utilisé par des modules ou des applications tiers. L'article suivant vous présente principalement un résumé des connaissances sur l'utilisation des bibliothèques de journalisation en Python. code, les amis dans le besoin peuvent s'y référer, jetons un coup d'œil ci-dessous.
Préface
Récemment, en raison de besoins professionnels, j'ai écrit des scripts python Il semble très faible de toujours utiliser print pour imprimer. informations, j'ai donc pris le temps. J'ai étudié la bibliothèque de journalisation de python pour imprimer et enregistrer les journaux avec élégance. Je n'entrerai pas dans plus de détails ci-dessous, jetons un œil à l'introduction détaillée.
1. Imprimez simplement le journal à l'écran :
import logging logging.debug('This is debug message') #debug logging.info('This is info message') #info logging.warning('This is warning message') #warn
Écran Imprimer sur : WARNING:root:This is warning message
Par défaut, les journaux de niveau AVERTISSEMENT seront imprimés
DEBUG : informations détaillées, informations de débogage.
INFO : Confirme que tout fonctionne comme prévu.
AVERTISSEMENT : indique que quelque chose d'inattendu s'est produit ou qu'un problème surviendra dans un avenir proche (comme « disque plein »). Le logiciel fonctionne toujours normalement.
ERREUR : En raison de problèmes plus graves, le logiciel ne peut plus exécuter certaines fonctions.
CRITIQUE : Une erreur grave indiquant que le logiciel ne peut plus fonctionner.
2. Configurez le format et la méthode de saisie du journal via la fonction basicConfig
import logging logging.basicConfig(level=logging.DEBUG, format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s', datefmt='%Y-%m-%d %a %H:%M:%S', filename='test.log', filemode='w') logging.debug('This is debug message') logging.info('This is info message') logging.warning('This is warning message')
Le code ci-dessus n'imprimera pas le journal à l'écran, mais générera le fichier journal test.log dans le répertoire courant. Le journal est imprimé dans le fichier journal :
%(levelno)s: 打印日志级别的数值 %(levelname)s: 打印日志级别名称 %(pathname)s: 打印当前执行程序的路径,其实就是sys.argv[0] %(filename)s: 打印当前执行程序名 %(funcName)s: 打印日志的当前函数 %(lineno)d: 打印日志的当前行号 %(asctime)s: 打印日志的时间 %(thread)d: 打印线程ID %(threadName)s: 打印线程名称 %(process)d: 打印进程ID %(message)s: 打印日志信息
3. Affichez le journal à l'écran et le fichier journal en même temps
#定义一个StreamHandler,将INFO级别或更高的日志信息打印到标准错误,并将其添加到当前的日志处理对象 console = logging.StreamHandler() console.setLevel(logging.INFO) formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s') console.setFormatter(formatter) logging.getLogger('').addHandler(console)
Imprimer sur l'écran :
root : INFO Ceci est un message d'information
root : AVERTISSEMENT Ceci est un message d'avertissement
Imprimer dans le fichier :
2017- 10-16 Lun 10:20:07 testlogging.py[line:46] DEBUG This est un message de débogage
2017-10-16 Lun 10:20:07 testlogging.py[line:47] INFO Ceci est un message d'information
2017-10-16 Lun 10:20:07 testlogging.py[line:48] AVERTISSEMENT Ceci est un message d'avertissement
4. Configurez les journaux via les fichiers de configuration
#logger.conf [loggers] #定义logger模块,root是父类,必需存在的,其它的是自定义。 keys=root,infoLogger,warnlogger [logger_root] level=DEBUG #level 级别,级别有DEBUG、INFO、WARNING、ERROR、CRITICAL handlers=infohandler,warnhandler #handlers 处理类,可以有多个,用逗号分开 [logger_infoLogger] #[logger_xxxx] logger_模块名称 handlers=infohandler qualname=infoLogger #qualname logger名称,应用程序通过 logging.getLogger获取。对于不能获取的名称,则记录到root模块。 propagate=0 #propagate 是否继承父类的log信息,0:否 1:是 [logger_warnlogger] handlers=warnhandler qualname=warnlogger propagate=0 ############################################### #定义handler [handlers] keys=infohandler,warnhandler [handler_infohandler] class=StreamHandler #class handler类名 level=INFO #level 日志级别 formatter=form02 #formatter,下面定义的formatter args=(sys.stdout,) #args handler初始化函数参数 [handler_warnhandler] class=FileHandler level=WARN formatter=form01 args=('logs/deploylog.log', 'a') ############################################### # 定义格式化输出 [formatters] keys=form01,form02 [formatter_form01] format=%(message)s %(asctime)s datefmt=%Y-%m-%d %H:%M:%S [formatter_form02] format=%(asctime)s %(levelname)s %(message)s datefmt=%Y-%m-%d %H:%M:%S
from logging.config import fileConfig fileConfig('logger.conf') logger=logging.getLogger('infoLogger') logger.info('test1') logger_error=logging.getLogger('warnhandler') logger_error.warn('test5')
Résumé
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!