BASH moyenne de 2 colonne

Résolu
donkey -  
 donkey -
Bonjour,
J'ai un fichier qui contient 2 colonne de chiffre et j'aimerais que qu'a la fin du fichier s'affiche la moyenne de chaque colonne

Exemple:

5 8
2 9
3 5
----
3.33 7,3


merci d'avance
A voir également:

4 réponses

jipicy Messages postés 40842 Date d'inscription   Statut Modérateur Dernière intervention   4 896
 
Salut,
[tmpfs]$ cat fich
5 8
2 9
3 5

[tmpfs]$ awk '{
print $0
}
{
sum1+=$1;sum2+=$2
}
END {
printf "%s\n%.2f %.2f\n","----------",sum1/NR,sum2/NR
}
' fich

5 8
2 9
3 5
----------
3,33 7,33

[tmpfs]$
;-))
1
donkey
 
merci mais je n'ai pas totalement saisi le fonctionnement du script (je débute)
si j'ai bien compris on stocke ce que contient les colonnes dans un variables temporaires, puis ensuite on reprend cette variable pour faire les calculs et on affiche le résultats ?
0
jipicy Messages postés 40842 Date d'inscription   Statut Modérateur Dernière intervention   4 896
 
En fait j'ai fait ça avec "awk", beaucoup plus adapté pour ce genre de traitement que du bash pur.

print $0
On affiche chaque ligne du fichier

sum1+=$1
On additionne le contenu de la colonne 1 que l'on stocke dans la variable sum1

sum2+=$2
On additionne le contenu de la colonne 2 que l'on stocke dans la variable sum2

printf "%s\n%.2f %.2f\n"
On formate l'affichage de la sortie.

sum1/NR
NR = le nombre de ligne. Donc total colonne que divise nombre de ligne

sum2/NR
idem
0
donkey
 
merci j'en aurais appris un peu plus durant la nuit ^^
0