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

Logging Java Discussion :

[log4j] Appender csv et formatage


Sujet :

Logging Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 349
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 349
    Par défaut [log4j] Appender csv et formatage
    Bonjour,
    je dois pour un projet récupérer des résultats intermédiaires de calcul donc sans modifier les logs actuels je pensais mettre en place un appender particulier qui si on est en mode debug formate un fichier csv.

    Mon soucis comment appliquer au message à logger une expression régulière
    car mon message est de ce type:

    chaine1 : chaine 2 = chaine 3

    et j'aimerait que pour mon fichier csv cela donne :

    chaine1;chaine 3

    Donc ma question savez vous comment est-il possible d'appliquer une expresison regulière au message et sinon voyez vous une autre méthode ?

  2. #2
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Par défaut
    bonjour,

    Il faut effectivement créer ton propre appender :

    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
    32
    import org.apache.log4j.AppenderSkeleton;
    import org.apache.log4j.spi.LoggingEvent;
    
    public class MonAppender extends AppenderSkeleton {
    
     public MonAppender() {
         super();
     }
    
     /**
      * @see org.apache.log4j.AppenderSkeleton#requiresLayout()
      */
     public boolean requiresLayout() {
         return true;
     }
    
     /**
      * @see org.apache.log4j.AppenderSkeleton#append(LoggingEvent)
      */
     protected void append(LoggingEvent event) {
         String text = super.getLayout().format(event);
         // il reste a faire le traitement souhaité
     }
    
     /**
      * @see org.apache.log4j.AppenderSkeleton#close()
      */
     public void close() {
         super.closed = true;
     }
    
    }
    Il est possible de récupérer le level sur le LoggingEvent pour vérifier si tu es en mode debug.
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre Expert
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 349
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 349
    Par défaut
    Merci pour ta réponse, et ça ne serait pas possible de formater dans le conversion pattern du fichier properties.

    %m correspond au message mais n'est-il pas possible de formater le message sans redéfinir un appender?

  4. #4
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Par défaut
    si en effet il est possible en mettant en place ton propre "Renderer"

    un exemple ici !
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  5. #5
    Membre Expert
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 349
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 349
    Par défaut
    Merci je regarde ça

  6. #6
    Membre Expert
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 349
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 349
    Par défaut
    Re,
    je pense que le mieux pour moi est donc de créer mon propre renderer par contre je n'arrive pas à définir mon renderer pour un appender particulier ..
    je précise que j'ai un fichier properties et on xml pour la config et même dans l'exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
     * <renderer renderedClass="com.apress.business.CustomerOrder"
     * renderingClass="com.apress.logging.log4j.renderer.OrderRenderer"> </renderer>
    jamais le renderer n'est attribué à un appender. je crois que je suis une vrai quiche concernant log4j.. :s

Discussions similaires

  1. [XL-2003] Import csv et formatage de copie
    Par CODYCO dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 16/05/2012, 09h09
  2. log4j:ERROR Could not find value for key log4j.appender
    Par quiquekoi dans le forum Logging
    Réponses: 0
    Dernier message: 28/07/2010, 09h26
  3. log4j appender.sql modifiable par le code
    Par audklie2 dans le forum Logging
    Réponses: 4
    Dernier message: 27/05/2009, 15h49
  4. [log4j] Appender
    Par lapartdombre dans le forum Servlets/JSP
    Réponses: 1
    Dernier message: 06/10/2005, 10h30
  5. [debutant][log4j] plusieurs appender
    Par Invité dans le forum Logging
    Réponses: 1
    Dernier message: 13/07/2005, 10h36

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