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

Shell et commandes GNU Discussion :

filtrage temps reel de la sortie d'un programme dans terminal


Sujet :

Shell et commandes GNU

  1. #1
    Membre habitué
    Inscrit en
    Décembre 2008
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Décembre 2008
    Messages : 10
    Par défaut filtrage temps reel de la sortie d'un programme dans terminal
    Salut à tous,

    J'ai un programme qui se lance dans un terminal et qui affiche une très grosse quantité de traces parmis lesquelles une infime partie m'intéresse. Je souhaiterais donc afficher seulement celles ci et du coup j'ai esssayé tout simplement la commande suivante pour lancer mon prog :

    mon_programme | grep "mot_cle"

    "mot_cle" me permet de distinguer mes traces. Cette manière de faire fonctionne mais il y a une sorte de bufferisation, je n'ai pas l'affichage en temps réel : au bout d'un certain temps les traces intérressantes s'affichent d'un coup par bloc d'une dizaine de ligne mais pas au fur et à mesure alors que je souhaiterai vraiment un filtrage temps reel de la sortie.

    J'ai essayé l'option --line-buffered de grep mais ça ne change rien, il semble pourtant qu'il y ait une bufferisation quelque part qui fait un "flush" trop tard.

    Quelqu'un sait-il comment éviter ça? Ou bien ya t-il une autre méthode que je ne connais que je pourrais utiliser pour filtrer en temps reel ma sortie stdout?

    Merci d'avance.

  2. #2
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 644
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 644
    Par défaut
    Bonjour filipaillou,

    avec l'éditeur de flux :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mon_programme | sed -n '/mot_cle/p'
    ...
    ?
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  3. #3
    Membre habitué
    Inscrit en
    Décembre 2008
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Décembre 2008
    Messages : 10
    Par défaut
    Merci pour la réponse mais le résultat est le même : je retrouve toutes mes traces par des gros blocs.

  4. #4
    Expert confirmé

    Avatar de Feanorin
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    4 589
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 4 589
    Par défaut
    avec la commande expect , elle intercepte le flux sur la commande .

    Expect is a program that "talks" to other interactive programs accord‐
    ing to a script. Following the script, Expect knows what can be
    expected from a program and what the correct response should be. An
    interpreted language provides branching and high-level control struc‐
    tures to direct the dialogue. In addition, the user can take control
    and interact directly when desired, afterward returning control to the
    script.

  5. #5
    Membre habitué
    Inscrit en
    Décembre 2008
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Décembre 2008
    Messages : 10
    Par défaut
    ok merci je vais essayer par contre ca n'a pas l'air trivial et je n'ai pas trop de temps pour le moment, to be continued

  6. #6
    Expert confirmé

    Avatar de Feanorin
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    4 589
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 4 589
    Par défaut
    T'as des exemples ici.
    [URL="http://envrac.blogdns.net/systemes/expect_pour_l_automatisation_de_taches_u"]

    l'idée est là

    set timeout -1
    spawn "ton programme"

    la commande send sert à envoyer des commandes à distance à ton programme

    expect {
    -re "texte a intercepter *" { tu as t'as chaine retourner dans $expect_out }
    }

Discussions similaires

  1. Rediriger sortie de script en temps reel
    Par raph382 dans le forum Débuter avec Java
    Réponses: 18
    Dernier message: 10/01/2011, 17h25
  2. Réponses: 9
    Dernier message: 16/02/2010, 19h50
  3. Réponses: 1
    Dernier message: 13/11/2008, 12h08
  4. récupérer le code de sortie d'un programme dans un c shell
    Par awalter1 dans le forum Shell et commandes GNU
    Réponses: 4
    Dernier message: 17/01/2008, 15h17
  5. Linux et le temps réel
    Par Shrem dans le forum Administration système
    Réponses: 6
    Dernier message: 11/12/2002, 08h21

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