PHWinfo banniere

Titres
PORTAIL ANNUAIRE ARTICLES COMPARATEUR HÉBERGEURS DEVIS FORUMS RÉDUCTEUR D'URL
Précédent   PHWinfo > Autres forums > Forum Programmation & Conception > fr.comp.lang.python > redirriger stdout et stderr
S'inscrire FAQ Membres Recherche Messages du jour Marquer les forums comme lus
redirriger stdout et stderr

Réponse
 
LinkBack Outils de la discussion
Vieux 02/11/2007, 12h24   #1
m.banaouas
Aucun Avatar
 
Messages: n/a
Hébergeur:
Par défaut redirriger stdout et stderr

bonjour à tous,

j'utilise le module smtplib et dans certains cas, l'envoi du message
échoue. J'ai bien intercepté l'exception générée ainsi que le log
(smtp_server.debuglevel=1) ce qui me fournit des info très utiles.

Question: comment redirriger stdout et stderr vers un flux interne à mon
script afin de le logger à mon tour et à ma façon?

merci.
  Réponse avec citation
Vieux 02/11/2007, 14h00   #2
Bruno Desthuilliers
Aucun Avatar
 
Messages: n/a
Hébergeur:
Par défaut Re: redirriger stdout et stderr

m.banaouas a écrit :
> bonjour à tous,
>
> j'utilise le module smtplib et dans certains cas, l'envoi du message
> échoue. J'ai bien intercepté l'exception générée ainsi que le log
> (smtp_server.debuglevel=1) ce qui me fournit des info très utiles.
>
> Question: comment redirriger stdout et stderr vers un flux interne à mon
> script afin de le logger à mon tour et à ma façon?
>
> merci.


import sys
class FakeStream(object):
def __init__(self):
self._data = []
def write(self, val):
self._data.append(val)
def __str__(self):
return "".join(map(str, self._data))

sys.stdout = FakeStream()
sys.stderr = FakeStream()

  Réponse avec citation
Vieux 05/11/2007, 07h48   #3
NicolasP
Aucun Avatar
 
Messages: n/a
Hébergeur:
Par défaut Re: redirriger stdout et stderr

Bruno Desthuilliers a écrit :
> m.banaouas a écrit :
>> bonjour à tous,
>>
>> j'utilise le module smtplib et dans certains cas, l'envoi du message
>> échoue. J'ai bien intercepté l'exception générée ainsi que le log
>> (smtp_server.debuglevel=1) ce qui me fournit des info très utiles.
>>
>> Question: comment redirriger stdout et stderr vers un flux interne à
>> mon script afin de le logger à mon tour et à ma façon?
>>
>> merci.

>
> import sys
> class FakeStream(object):
> def __init__(self):
> self._data = []
> def write(self, val):
> self._data.append(val)
> def __str__(self):
> return "".join(map(str, self._data))
>
> sys.stdout = FakeStream()
> sys.stderr = FakeStream()
>

Ne serait t-il pas préférable de sauvegarder sys.stdout et sys.stderr avant ?
Histoire de pouvoir y revenir si nécessaire.

Nicolas
  Réponse avec citation
Vieux 05/11/2007, 08h35   #4
Bruno Desthuilliers
Aucun Avatar
 
Messages: n/a
Hébergeur:
Par défaut Re: redirriger stdout et stderr

NicolasP a écrit :
> Bruno Desthuilliers a écrit :
>> m.banaouas a écrit :
>>> bonjour à tous,
>>>
>>> j'utilise le module smtplib et dans certains cas, l'envoi du message
>>> échoue. J'ai bien intercepté l'exception générée ainsi que le log
>>> (smtp_server.debuglevel=1) ce qui me fournit des info très utiles.
>>>
>>> Question: comment redirriger stdout et stderr vers un flux interne à
>>> mon script afin de le logger à mon tour et à ma façon?
>>>
>>> merci.

>>
>> import sys
>> class FakeStream(object):
>> def __init__(self):
>> self._data = []
>> def write(self, val):
>> self._data.append(val)
>> def __str__(self):
>> return "".join(map(str, self._data))
>>
>> sys.stdout = FakeStream()
>> sys.stderr = FakeStream()
>>

> Ne serait t-il pas préférable de sauvegarder sys.stdout et sys.stderr
> avant ? Histoire de pouvoir y revenir si nécessaire.


Ils le sont déjà, dans sys.__stdout__ et sys.__stderr__

  Réponse avec citation
Vieux 05/11/2007, 12h42   #5
NicolasP
Aucun Avatar
 
Messages: n/a
Hébergeur:
Par défaut Re: redirriger stdout et stderr

Bruno Desthuilliers a écrit :
> NicolasP a écrit :
>> Bruno Desthuilliers a écrit :
>>> m.banaouas a écrit :
>>>> bonjour à tous,
>>>>
>>>> j'utilise le module smtplib et dans certains cas, l'envoi du message
>>>> échoue. J'ai bien intercepté l'exception générée ainsi que le log
>>>> (smtp_server.debuglevel=1) ce qui me fournit des info très utiles.
>>>>
>>>> Question: comment redirriger stdout et stderr vers un flux interne à
>>>> mon script afin de le logger à mon tour et à ma façon?
>>>>
>>>> merci.
>>>
>>> import sys
>>> class FakeStream(object):
>>> def __init__(self):
>>> self._data = []
>>> def write(self, val):
>>> self._data.append(val)
>>> def __str__(self):
>>> return "".join(map(str, self._data))
>>>
>>> sys.stdout = FakeStream()
>>> sys.stderr = FakeStream()
>>>

>> Ne serait t-il pas préférable de sauvegarder sys.stdout et sys.stderr
>> avant ? Histoire de pouvoir y revenir si nécessaire.

>
> Ils le sont déjà, dans sys.__stdout__ et sys.__stderr__
>

Je le note.
  Réponse avec citation
Réponse


Outils de la discussion

Règles de messages
Vous ne pouvez pas créer de nouvelles discussions
Vous ne pouvez pas envoyer des réponses
Vous ne pouvez pas envoyer des pièces jointes
Vous ne pouvez pas modifier vos messages

Les balises BB sont activées : oui
Les smileys sont activés : oui
La balise [IMG] est activée : oui
Le code HTML peut être employé : non
Trackbacks are oui
Pingbacks are oui
Refbacks are oui


Fuseau horaire GMT +1. Il est actuellement 23h43.


Édité par : vBulletin® version 3.7.2
Copyright ©2000 - 2008, Jelsoft Enterprises Ltd.
Search Engine Friendly URLs by vBSEO 3.2.0 RC5 Tous droits réservés.
Version française #16 par l'association vBulletin francophone
PHWinfo est un site Éducation Sans Frontières
Ad Management by RedTyger
©Tous droits réservés par les parties respectives
Page generated in 0,10894 seconds with 13 queries