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 :

Fichier script .awk


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Février 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2013
    Messages : 3
    Par défaut Fichier script .awk
    Bonjour ,
    Je suis débutant pour l'utilisation des scripts .awk. J'ai un fichier .txt comme ceci:
    1 0.1
    1 0.2
    1 0.3
    2 0.5
    2 0.6
    2 0.7
    3 0.9
    3 0.11
    3 0.12
    4 0.14
    4 0.15
    4 0.16
    5 0.19
    5 0.20
    5 0.21

    Je veux parcourir ce fichier pour calculer a chaque valeur de la première colonne la somme des valeurs correspondant dans la deuxième colonne c'est à dire je veux avoir une résultat comme ceci:
    1 0.6
    2 1.8
    3 1.13
    4 0.45
    5 0.6
    Merci pour votre réponse.

  2. #2
    Expert confirmé Avatar de BufferBob
    Profil pro
    responsable R&D vidage de truites
    Inscrit en
    Novembre 2010
    Messages
    3 041
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : responsable R&D vidage de truites

    Informations forums :
    Inscription : Novembre 2010
    Messages : 3 041
    Par défaut
    salut,

    on peut tirer parti des tableaux associatifs de awk, de telle façon que pour chaque ligne qui commence par la même valeur on ajoute la 2e valeur à l'entrée du tableau correspondante, à la fin on récapitule en affichant le tableau, le fichier script.awk ressemble alors à ça :
    Code awk : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    {
       tab[$1] += $2;
    }
     
    END {
       for (i in tab) {
          print i " " tab[i];
       }
    }
    et l'exécution :
    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $ awk -f script.awk fichier.txt
    1 0.6
    2 1.8
    3 1.13
    4 0.45
    5 0.6

    mais on peut faire ça de manière plus directe sans passer par un script.awk :
    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $ awk '{tab[$1]+=$2} END {for (i in tab){print i " " tab[i]}}' fichier.txt
    1 0.6
    2 1.8
    3 1.13
    4 0.45
    5 0.6

  3. #3
    Futur Membre du Club
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Février 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2013
    Messages : 3
    Par défaut
    Salut ,
    Je vous remercie pour votre réponse.Mais quand j'ai testé le script.awk il me donne le résultat suivant:
    4 0.45
    5 0.6
    1 0.6
    2 1.8
    3 1.13
    les lignes ne sont pas ordonnées.
    Que ce que je vais varier ou ajouter pour avoir les lignes de 1 à 5.

  4. #4
    Expert confirmé Avatar de Flodelarab
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    5 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 287
    Par défaut
    Bonjour

    Pour trier les indices d'un tableau, regarde "sorted" dans la documentation awk.

    Sinon, je voulais dire qu'avec un shebang, on pouvait appeler le script comme un exécutable à part entière.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    #!/usr/bin/awk -f
     
    {
       tab[$1] += $2;
    }
     
    END {
       for (i in tab) {
          print i " " tab[i];
       }
    }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $ ./script.awk fichier.txt

  5. #5
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 347
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 347
    Par défaut
    Bonjour,
    Une autre version awk (si les indices sont bien triés comme dans l'exemple):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    awk 'A==$1{I=0;B=B+$2}A!=$1{I=1;C=A;D=B;B=$2;A=$1;$2=D;$1=C}I;END{$2=B;print}' fichier.txt
    Il serait bien de faire une vrai version builtin bash

  6. #6
    Futur Membre du Club
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Février 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2013
    Messages : 3
    Par défaut
    Bonjour,

    Merci pour votre aide. J'ai reçu à afficher les lignes ordonnées en remplaçant le boucle for :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    {
       tab[$1] += $2;
    }
     
    END {
       for (i=1;i<=5;i++) {
          print i " " tab[i];
       }
    }
    Cordialement.

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

Discussions similaires

  1. Script AWK et traitement de fichier
    Par pcsystemd dans le forum Administration système
    Réponses: 10
    Dernier message: 12/06/2009, 17h18
  2. duree pour parser un fichier avec un script awk
    Par kass28 dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 26/03/2008, 16h35
  3. Script AWK pour fichiers xyz
    Par Frankii dans le forum Linux
    Réponses: 4
    Dernier message: 26/07/2007, 21h57
  4. Script awk ou ksh pour découper un fichier xml
    Par Griffith dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 15/05/2007, 22h58

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