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 :

Comment configurer le logger pour utiliser le séparateur de fin de ligne d'UNIX : LF


Sujet :

Python

  1. #1
    Membre éclairé
    Inscrit en
    Novembre 2008
    Messages
    308
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 308
    Par défaut Comment configurer le logger pour utiliser le séparateur de fin de ligne d'UNIX : LF
    Bonjour,

    J'utilise le module loggin de python 2.6.
    Actuellement, mon logger utilise le code DOS de retour à la ligne : CRLF.
    Je voudrais le configurer pour qu'il utilise le code UNIX : LF.

    Comment je peux faire cela ?

    Cordialement.

  2. #2
    Expert confirmé
    Avatar de fred1599
    Homme Profil pro
    Lead Dev Python
    Inscrit en
    Juillet 2006
    Messages
    4 044
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Lead Dev Python
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4 044
    Par défaut
    Tu peux l'avoir automatiquement en utilisant os.linesep

    Bonne continuation...

  3. #3
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 683
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 683
    Par défaut
    Salut,
    Juste pour bien comprendre le "pourquoi" de la question: votre application remplit un "log" sous Windows que vous aimeriez relire depuis U*X mais les fin de lignes vous embêtent? Sinon quel est le scenario?
    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  4. #4
    Membre éclairé
    Inscrit en
    Novembre 2008
    Messages
    308
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 308
    Par défaut
    @wiztricks : c'est exactement ça.

    @fred1599 : je te remercie. Je vais voir ça.

  5. #5
    Membre éclairé
    Inscrit en
    Novembre 2008
    Messages
    308
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 308
    Par défaut
    @fred1599 : j'ai ajouté
    au début de mon programme et j'ai eu dans le fichier de log des CRLF
    J'ai remplacé \r par \n et j'ai eu le même résultat.
    Est-ce que j'ai raté une étape ?

  6. #6
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 683
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 683
    Par défaut
    Citation Envoyé par yo_haha Voir le message
    @wiztricks : c'est exactement ça.
    Ok.
    Il faut aller voir dans les sources ou dans la doc (je ne le fais plus pour Python2) la classe qui s'appelle StreamHandler.
    C'est la que sont écrits les records avec des /write/ et un /terminator/ en attribut de classe.
    Après, il faut voir comment remplacer ce /terminator/: patch a la volée ou s/classe.
    Puis tester.

    Techniquement, il serait préférable d'adapter cote "lecture", depuis U*X, plutôt que de créer, sous Windows, un fichier texte "alien": difficile a exploiter "localement".

    Bon courage,
    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  7. #7
    Expert confirmé
    Avatar de fred1599
    Homme Profil pro
    Lead Dev Python
    Inscrit en
    Juillet 2006
    Messages
    4 044
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Lead Dev Python
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4 044
    Par défaut
    Est-ce que j'ai raté une étape ?
    Plus que ça même

    Tu n'as pas lu la documentation et tu n'as pas testé dans ton interpréteur.

    os.linesep détecte le système d'exploitation courant lors de l'utilisation du programme et retourne soit '\r\n' (windows), soit '\n' (unix)

    Du coup je le fais pour toi

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    >>> import os
    >>> import sys
    >>> sys.platform
    'linux'
    >>> os.linesep
    '\n'
    Bonne continuation...

  8. #8
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 683
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 683
    Par défaut
    @fred
    Le soucis est que c'est une "constante": la changer ne servira a pas grand chose cote logging (sinon a foutre la grouille ailleurs).
    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  9. #9
    Expert confirmé
    Avatar de fred1599
    Homme Profil pro
    Lead Dev Python
    Inscrit en
    Juillet 2006
    Messages
    4 044
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Lead Dev Python
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4 044
    Par défaut
    @wiztricks

    Je dirais même plus, les caractères de fin de ligne, n'ont aucun intérêt avec ce module...

  10. #10
    Membre éclairé
    Inscrit en
    Novembre 2008
    Messages
    308
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 308
    Par défaut
    @fred1599 : j'ai fait le test.
    os.linesep = \r\n sur ma plateforme windows32.

    @wiztricks : je vais essayer de changer la lecture du fichier depuis la plateforme unix.

  11. #11
    Expert confirmé
    Avatar de fred1599
    Homme Profil pro
    Lead Dev Python
    Inscrit en
    Juillet 2006
    Messages
    4 044
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Lead Dev Python
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4 044
    Par défaut
    os.linesep = \r\n sur ma plateforme windows32.
    C'est cool tout ça, mais tu en conclus quoi finalement?

  12. #12
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 683
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 683
    Par défaut
    Citation Envoyé par fred1599 Voir le message
    @wiztricks

    Je dirais même plus, les caractères de fin de ligne, n'ont aucun intérêt avec ce module...
    Pour relire le log... çà compte un peu, beaucoup,... quand même.
    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  13. #13
    Membre éclairé
    Inscrit en
    Novembre 2008
    Messages
    308
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 308
    Par défaut
    J'en conclue que je vais essayer de changer la façon de lire le fichier de log sur la plateforme Unix.
    C'est du Java. Je n'ai pas encore trouvé la bonne façon de faire.

  14. #14
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 683
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 683
    Par défaut
    Citation Envoyé par yo_haha Voir le message
    J'en conclue que je vais essayer de changer la façon de lire le fichier de log sur la plateforme Unix.
    C'est du Java. Je n'ai pas encore trouvé la bonne façon de faire.
    Normalement, la méthode readLine de la classe java.io.BufferedInputReader sait traiter les fins de lignes aussi "proprement" que Python.
    Mais il y a le forum Java serait plus indique pour cette question la.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  15. #15
    Membre éclairé
    Inscrit en
    Novembre 2008
    Messages
    308
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 308
    Par défaut
    Merci à tous

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 1
    Dernier message: 22/02/2010, 13h24
  2. Réponses: 3
    Dernier message: 17/04/2008, 11h42
  3. [VB.NET] Comment configurer le LocalPort pour le socket
    Par predictus dans le forum VB.NET
    Réponses: 1
    Dernier message: 15/03/2007, 19h51
  4. Réponses: 3
    Dernier message: 19/12/2006, 19h38
  5. [VB6 > VB.Net] Comment réussir la migration pour utilisation sous VS2003 ?
    Par sympatique dans le forum Accès aux données
    Réponses: 3
    Dernier message: 15/08/2006, 21h32

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