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

Linux Discussion :

[gawk/shell] moyenne de réels


Sujet :

Linux

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Inscrit en
    Septembre 2006
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 9
    Par défaut [gawk/shell] moyenne de réels
    Bonjour,

    j'ai un fichier de 5 colonnes avec des nombres réels, je souhaite faire une moyenne simple par ligne de ces 5 colonnes.

    ma ligne de commande est :
    gawk '{printf "%6.2f\n",($1+$2+$3+$4+$5)/5}' file1 > file2

    gawk me fait une moyenne des valeurs entières de chacune des colonnes, au lieu de considérer la valeur réelle.
    pourtant j'ai spécifié une sortie au format réel dans file2, mais peut-être faut il préciser le format des colonnes (nombres réels) dans file1?

    Auriez vous une idée ?? parceque

    si ce n'est pas clair, faites moi signe !

    Merci d'avance

  2. #2
    Membre habitué
    Inscrit en
    Septembre 2006
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 9
    Par défaut
    si ça peut aider quelqu'un, on m'a filé la solution sur un autre forum: il faut des virgules pour les champs en entrée à la place des points et ça marche nickel !

    la conversion est tout à fait faisable avec :
    - un éditeur de texte (remplacer . par ,)
    - en vi avec la commande [echap] :1,$s/./,,
    - ou encore, avec awk lui même : 1. echo "12.5" | awk '{gsub(/\./, "," ); print $1}'

  3. #3
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 840
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par manoro Voir le message
    si ça peut aider quelqu'un, on m'a filé la solution sur un autre forum: il faut des virgules pour les champs en entrée à la place des points et ça marche nickel !

    la conversion est tout à fait faisable avec :
    - un éditeur de texte (remplacer . par ,)
    - en vi avec la commande [echap] :1,$s/./,,
    - ou encore, avec awk lui même : 1. echo "12.5" | awk '{gsub(/\./, "," ); print $1}'
    Ou avec sed
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed -e "s/\./,/g" file1 |gawk '{printf "%6.2f\n",($1+$2+$3+$4+$5)/5}' > file2
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 26/10/2010, 22h14
  2. Comment utiliser le type réel en shell ?
    Par thouraya24 dans le forum Shell et commandes GNU
    Réponses: 5
    Dernier message: 28/02/2009, 15h41
  3. Réponses: 3
    Dernier message: 25/03/2008, 11h20
  4. Commande shell relative aux HDD
    Par Alpha31 dans le forum Linux
    Réponses: 2
    Dernier message: 24/11/2006, 13h41
  5. Programmation Shell avec Red Hat Calcul de moyenne
    Par jcpoulard dans le forum Linux
    Réponses: 3
    Dernier message: 22/02/2006, 22h08

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