IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Python Discussion :

module logging: personaliser le logger d'un module externe


Sujet :

Python

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2008
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 12
    Points : 11
    Points
    11
    Par défaut module logging: personaliser le logger d'un module externe
    Bonjour,

    Je vous pose cette question pour laquelle je n'ai trouvé de réponse ni dans la doc, ni sur le net. Je passe peut être à coté de qqch d'évident...

    Soit l'arborescence suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    .
    |-- main.py
    `-- module
        |-- __init__.py
        `-- mod.py
    Le fichier __init__.py est vide.

    Le fichier mod.py contient :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
     
    import logging
    logger = logging.getLogger(__name__)
     
    def mafunc():
        logger.critical('message critique')
    Noter que comme le recommande la doc, je ne mets pas de formatter ni de level dans la lib.

    Mon fichier main.py contient :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
     
     
    from module import mod
     
     
    import logging
     
    ######
    #LOGS
    ######
    logger = logging.getLogger('monprog')
     
    #Console
    consolehandler = logging.StreamHandler()
    consolehandler.setLevel(logging.ERROR)
    formatter = logging.Formatter('%(name)s - %(levelname)s - %(message)s')
    consolehandler.setFormatter(formatter)
    logger.addHandler(consolehandler)
     
     
     
    def main():
        logger.critical('Message depuis le main')
        mod.mafunc()
     
    if __name__ == '__main__':
        main()
    La sortie est la suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    monprog - CRITICAL - Message depuis le main
    message critique
    Ce que je voudrais avoir :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    monprog - CRITICAL - Message depuis le main
    module.mod - CRITICAL - message critique
    En clair, je veux que la configuration que j'ai déclaré dans mon main.py soit utilisée pour les messages issues des libs externes (ici module.mod).

    A noter que si dans mod.py j'avais écrit
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    logger = logging.getLogger('monprog.mod')
    J'aurai eu
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    monprog - CRITICAL - Message depuis le main
    monprog.mod - CRITICAL - message critique
    et ça, je le conçois très bien puisque par défaut il y a héritage pour les loggers fils.


    Quelqu'un a t-il la solution ?
    Merci.

    Remarque : je travaille avec python 3.

  2. #2
    Expert éminent

    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    4 298
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2008
    Messages : 4 298
    Points : 6 778
    Points
    6 778
    Par défaut
    Bonjour,

    Je n'ai jamais utilisé de StreamHandler par contre ceci produit exactement le résultat que tu attends.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
     
    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
     
    from module import mod
     
    import logging
     
    logger = logging.getLogger('monprog')
    lvl = logging.ERROR
    form = "%(asctime)-6s %(levelname)s: %(name)s - %(message)s"
    logging.basicConfig(format=form, datefmt='%H:%M:%S', level=lvl)
     
     
    def main():
        logger.critical('Message depuis le main')
        mod.mafunc()
     
    if __name__ == '__main__':
        main()
    vincent@tiemoko:~/Bureau/logtest$ python3 main.py
    07:47:13 CRITICAL: monprog - Message depuis le main
    07:47:13 CRITICAL: module.mod - message critique

    vincent@tiemoko:~/Bureau/logtest$ python main.py
    07:47:22 CRITICAL: monprog - Message depuis le main
    07:47:22 CRITICAL: module.mod - message critique

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2008
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 12
    Points : 11
    Points
    11
    Par défaut
    Je trouve ta réponse intéressante, je précise en quoi dans la suite.


    Je viens de transformer mon fihier main.py en ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
     
     
     
    from module import mod
     
     
    import logging
     
    ######
    #LOGS
    ######
    logger = logging.getLogger()
    logger.name = 'monprog' 
     
    #Console
    consolehandler = logging.StreamHandler()
    consolehandler.setLevel(logging.ERROR)
    formatter = logging.Formatter('%(name)s - %(levelname)s - %(message)s')
    consolehandler.setFormatter(formatter)
    logger.addHandler(consolehandler)
     
     
     
    def main():
        logger.critical('Message depuis le main')
        mod.mafunc()
     
    if __name__ == '__main__':
        main()
    A savoir que je nomme mon logger après. Alors, j'ai la sortie suivante

    monprog - CRITICAL - Message depuis le main
    module.mod - CRITICAL - message critique
    Étonnamment, ce n'est pas le cas de basicConfig. Et je ne comprends pas pourquoi.
    Et je comprends pas pourquoi ma nouvelle mouture fonctionne.

    J'en suis presque à me demander si ce n'est pas un bug.

Discussions similaires

  1. le module Logging et relativeCreated
    Par rosty38 dans le forum Général Python
    Réponses: 3
    Dernier message: 15/10/2010, 16h46
  2. [1.x] Personaliser le design d'un module généré par Admin Generator
    Par belgacem.tlili dans le forum Symfony
    Réponses: 3
    Dernier message: 01/08/2010, 14h41
  3. Module logging : reinitialiser de force
    Par ulysse_31 dans le forum Général Python
    Réponses: 19
    Dernier message: 27/04/2010, 22h40
  4. Rediriger les erreurs en utilisant le module logging
    Par kazh75 dans le forum Général Python
    Réponses: 5
    Dernier message: 12/02/2009, 10h59
  5. Module logging, classe SMTPHandler
    Par kazh75 dans le forum Réseau/Web
    Réponses: 1
    Dernier message: 07/04/2007, 21h47

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo