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 :

[bash] Comparaison de string


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2008
    Messages : 9
    Par défaut [bash] Comparaison de string
    Bonjour à tous,

    Je suis en train d'écrire un script qui à pour but de parser un fichier de logs et d'en sortir uniquement les infos qui m'intèresse.

    Les infos dans ce fichier sont sous cette forme :


    ================New Request: [GET /brol/brol/ HTTP/1.1] =================
    Thu Aug 5 14:06:25 2010 <208612810099851> INFO: SSL is not configured
    Thu Aug 5 14:06:25 2010 <208612810099851> Using Uri /brol/brol/
    Thu Aug 5 14:06:25 2010 <208612810099851> After trimming path: '/brol/brol/'
    Thu Aug 5 14:06:25 2010 <208612810099851> The final request string is '/brol/brol/'
    .
    .
    .
    .
    .
    .
    Thu Aug 5 14:06:25 2010 <208612810099851> canRecycle: conn=1 status=302 isKA=1 clen=-1 isCTE=1
    Thu Aug 5 14:06:25 2010 <208612810099851> request [/brol/brol/] processed successfully..................
    Ceci est l'exemple pour une requête mais le fichier en contient des milliers.
    J'ai besoin de parser ce fichier en extrayant seulement la première (New Request) et la derniere (processed successfully) ligne de la requête et ceci pour toutes les requêtes dans le fichier de log.

    Voici mon script :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    #!/bin/bash
     
    while read ligne;  do
            #echo $ligne
            if [[ "$ligne" == "*New Request*" ]]; then
                    echo $ligne
                    read ligne_interne
                    echo $ligne_interne
                    while [[  "$ligne_interne" != "*processed successfully*" ]; do
                            read ligne_interne
                    done
            fi
    done < stats.log
    Malheureusement, il ne m'affiche rien, le script n'entre pas dans le if.
    Voyez vous le soucis? Je n'ai pas d'erreur au moment où j'exécute le script.
    Je travaille sous Solaris 8.

    Vous voyez quelque chose?

    Merci d'avance pour votre aide.

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 651
    Par défaut
    bonjour,

    bash est une contrainte ? parce que sinon :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed -n '/New Request\|processed successfully/p'
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    awk '/New Request|processed successfully/'
    et hop !
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2008
    Messages : 9
    Par défaut
    Oui et non... :o)

    1) Merci pour ta réponse rapide et la puissance de tes commandes, je me suis compliqué la vie.

    2) En fait le soucis est que je dois faire une différence de 2 temps pour pouvoir calculer le temps qu'a duré la requête, et je peux obtenir le 1er temps en prennant la ligne suivant celle contenant "New Request". Cette ligne n'a pas de chaine de caractère distincte... C'est aléatoire. C'est pour ça que je parcourais le fichier. Sinon pour avoir l'heure, un simple awk '{print $4}' devrait effectivement suffire.

    Une idée pour avoir la 2ème ligne ?

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 651
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    awk '/New Request/{getline; date=$4}; /processed successfully/ {print date,$4}'
    ensuite, il faut voir, selon la version de awk disponible sur Solaris, comment soustraire 'date' de '$4'
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  5. #5
    Membre éprouvé Avatar de nowahn
    Homme Profil pro
    Inscrit en
    Août 2008
    Messages
    84
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 84
    Par défaut
    Bonjour,

    Citation Envoyé par NicX2610
    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    	if [[ "$ligne" == "*New Request*" ]]; then
    [...]
    [...] le script n'entre pas dans le if.
    [...]
    Vous voyez quelque chose?
    Pour répondre à cette question, il ne faut pas de guillemets autour du deuxième argument du == :
    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    	if [[ "$ligne" == *New\ Request* ]]; then
    Note que, du coup, il faut un \ devant l’espace.

    Bon, c’était juste pour ne pas te laisser dans le mystère, les solutions de N_BaH avec sed et awk sont bien meilleures pour ce que tu veux faire.

  6. #6
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2008
    Messages : 9
    Par défaut
    Merci N_BaH pour la puissance d'awk dont je ne connais pas toutes les nombreuses possibilités.

    Merci nowahn pour la correction de la synthaxe de bash. Clairement que awk est mieux adapté à ma requête. J'ai souvent un soucis avec "le bon outil" a utilisé pour faire tel ou tel boulot...

    Sujet résolu,

    Bonne journée

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

Discussions similaires

  1. Problème script bash (comparaison de string)
    Par nicoo04 dans le forum Linux
    Réponses: 2
    Dernier message: 26/01/2011, 22h23
  2. pb de comparaison de string
    Par Kpone dans le forum Langage
    Réponses: 2
    Dernier message: 03/03/2006, 23h31
  3. [LG] Comparaison de strings
    Par Pack_of_the_Night dans le forum Langage
    Réponses: 2
    Dernier message: 09/02/2006, 20h58
  4. Réponses: 1
    Dernier message: 24/12/2005, 14h18
  5. [C#] Erreur comparaison de string
    Par Damsou dans le forum ASP.NET
    Réponses: 13
    Dernier message: 11/02/2005, 11h14

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