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.
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.
Tu peux l'avoir automatiquement en utilisant os.linesep
Bonne continuation...
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
@wiztricks : c'est exactement ça.
@fred1599 : je te remercie. Je vais voir ça.
@fred1599 : j'ai ajouté
au début de mon programme et j'ai eu dans le fichier de log des CRLF
Code : Sélectionner tout - Visualiser dans une fenêtre à part os.linesep = "\r"
J'ai remplacé \r par \n et j'ai eu le même résultat.
Est-ce que j'ai raté une étape ?
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
Plus que ça mêmeEst-ce que j'ai raté une étape ?
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
Bonne continuation...
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'
@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
@wiztricks
Je dirais même plus, les caractères de fin de ligne, n'ont aucun intérêt avec ce module...
@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.
C'est cool tout ça, mais tu en conclus quoi finalement?os.linesep = \r\n sur ma plateforme windows32.
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.
Merci à tous![]()
Partager