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 :

AWK problème de comparaison


Sujet :

Shell et commandes GNU

  1. #1
    Membre confirmé
    Inscrit en
    Juillet 2008
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 80
    Par défaut AWK problème de comparaison
    Bonjour,

    Je souhaiterai faire une comparaison sur le champ 3 du traitement de la boucle AWK s'il est compris entre 0 et 9.

    Le code suivant ne fonctionne pas.
    J'ai essayé sans les "" mais sans résultat.

    Merci pour votre aide

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    awk -F ';' -v out="$temp/GF_P_CIGAS_TMP3.dat" '{ 
      if ($3 == "[0-9]")
      {
      printf ("%s %s %s;%s;\n", $2, $3, $4, $1) >> out;
      }
    }' $temp/GF_P_CIGAS.dat

  2. #2
    Membre émérite Avatar de jmelyn
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Septembre 2007
    Messages
    703
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Septembre 2007
    Messages : 703
    Par défaut
    Bonjour,

    Dans la comparaison, == veut dire égalité stricte. Si c'est une expression régulière, alors ~ est la comparaison idoine. Et quelques modifs... cela donne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    awk -F ';' '
    {
        if ($3 ~ /^[0-9]$/
        {
            printf "%s %s %s;%s;\n", $2, $3, $4, $1
        }
    }' $temp/GF_P_CIGAS.dat > $temp/GF_P_CIGAS_TMP3.dat
    Le champ 3 ne peut prendre que 10 valeurs différentes: de 0 à 9. Et dans ce cas, on affiche $2, $3, $4 et $1.

  3. #3
    Membre confirmé
    Inscrit en
    Juillet 2008
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 80
    Par défaut
    Encore une fois merci à jmelyn, c'est la deuxième fois cette semaine!

    J'ai un peu simplifié et ça fonctionne nickel

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    awk -F ';' -v out="$temp/GF_P_CIGAS_TMP3.dat" ' 
    $3 ~ /^[0-9]$/ {printf ("%s 0%s %s;%s;\n", $2, $3, $4, $1) >> out;}' $temp/GF_P_CIGAS.dat

  4. #4
    Membre émérite Avatar de jmelyn
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Septembre 2007
    Messages
    703
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Septembre 2007
    Messages : 703
    Par défaut
    Très juste pour avoir sorti le test de l'action. Voilà ce qui arrive lorsque je réponds trop vite. Cependant je préfère rediriger la sortie standard du awk vers un fichier, je trouve plus lisible d'avoir les fichiers d'entrée et de sortie l'un à côté de l'autre: awk '...' fichier_in > fichier_out. Et puis c'est une manière habituelle de travailler en script, pas besoin de voir ce qu'on fait avec la variable out dans le programme awk.

    Mais ça n'est que mon avis.

Discussions similaires

  1. Réponses: 2
    Dernier message: 23/03/2006, 12h39
  2. Réponses: 11
    Dernier message: 22/03/2006, 21h57
  3. problème de comparaison table dans requète.
    Par Sendo dans le forum Access
    Réponses: 8
    Dernier message: 09/03/2006, 11h10
  4. Problème de comparaison (chez lycos)
    Par Tuscelan dans le forum Langage
    Réponses: 4
    Dernier message: 10/11/2005, 18h13
  5. Problème de comparaison de dates
    Par MiJack dans le forum Langage SQL
    Réponses: 2
    Dernier message: 12/03/2004, 21h43

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