2015-06-15 95 views
-1

我想要計算除了值爲「9999」的行之外的第5列(最後一列)的平均值。希望你的反饋。使用AWK查找排除某些行的列的平均值

77.300 16 1 3.6112914285714268 9.4 
77.300 16 2 -0.001737142857145102 20.0 
77.300 16 3 5.1570742857142857 8.9 
77.300 17 0 3.6112914285714268 8.9 
77.300 17 1 2.9484342857142849 11.7 
77.300 17 2 -0.001737142857145102 22.6 
77.300 17 3 3.5098971428571417 9.2 
77.300 18 0 3.5098971428571417 9.4 
77.300 18 1 2.9484342857142849 14.0 
77.300 18 2 -0.001737142857145102 24.7 
77.300 18 3 3.5098971428571417 9.4 
77.650 13 0 3.2896914285714267 9.4 
77.650 13 1 0.0042514285714272404 24.9 
77.650 13 2 2.0769371428571421 9.1 
77.650 13 3 0.0042514285714272404 99999 
77.650 14 0 1.8255085714285713 9.3 
77.650 14 1 0.0042514285714272404 99999 
77.650 14 2 1.8255085714285713 9.2 
77.650 14 3 0.0042514285714272404 99999 
77.650 15 0 3.2896914285714267 8.7 
77.650 15 1 4.2542171428571418 8.7 
+6

由於您使用[awk]作爲標記,因此您可能對此有一些瞭解。發佈您的嘗試,以便我們可以幫助您完成問題。 – fedorqui

回答

2

通過AWK,

$ awk '$5!="99999"{sum+=$5}END{print sum}' file 
227.5 

說明:

  • $5!="99999"如果第5列不包含99999,然後做

  • {sum+=$5}將第5列的值加到變量sum。同樣,當awk查看滿足給定條件的記錄時,它會不斷添加第5列的值。

  • 最後在最後打印變量sum

對於一般。

$ awk '$5!="99999"{sum+=$5;cnt++}END{print (cnt?sum/cnt:"NaN")}' file 
12.6389 
+1

你,你是對的。吻原則.. –