尋找特定列中每 10 行的最大值並列印整行

尋找特定列中每 10 行的最大值並列印整行

我想找出第 1 列中的最大值。每 10 行 5(確定),然後列印對應的整行。例如。在前 10 行中,第 5 列的最大值為“1.1824”,對應的整行為“10_M62 6: 3.0561 405.69 1.1824”。我想找到每 10 行第 5 列中的最大值,然後列印整列,如上所示。

我嘗試了以下命令,它適用於前 30 行,之後給出了錯誤的答案。我不確定我錯過了什麼。請幫助我。

awk 'm<$10{m=$10;n=$5" "$2$3 $4" "$6" "$7" "$8" "$9} !((NR+2)%10){print $1,n,m;m=n=""}'

如果我不清楚,請告訴我。我在下面給出了示例列表。

Name      No.           Value1   Value2   Determine
 
10_M62    1:            2.4578   504.44   0.0013  
10_M62    2:            2.6155   474.03   0.0010  
10_M62    3:            2.8581   433.80   0.0418  
10_M62    4:            2.9552   419.54   0.3863  
10_M62    5:            2.9809   415.93   0.1014  
10_M62    6:            3.0561   405.69   1.1824  
10_M62    7:            3.3083   374.77   0.0719  
10_M62    8:            3.5159   352.63   0.0242  
10_M62    9:            3.6366   340.94   0.0023  
10_M62   10:            3.6553   339.19   0.0049  
11_M63    1:            1.9677   630.10   0.0075  
11_M63    2:            2.3544   526.62   1.8099  
11_M63    3:            2.7363   453.12   0.0028  
11_M63    4:            2.7437   451.88   0.0044  
11_M63    5:            2.8913   428.81   0.0569  
11_M63    6:            2.9497   420.32   0.3310  
11_M63    7:            2.9688   417.63   0.0889  
11_M63    8:            3.0038   412.76   0.0330  
11_M63    9:            3.0792   402.65   0.2730  
11_M63   10:            3.0805   402.48   0.0914  
...

答案1

即使您的輸入值都是負數和/或您的輸入不是10 行的精確倍數,並且無論您的標題行和資料之間有多少個空行,這都可以在每個UNIX 機器上的任何shell 中使用任何awk:

$ cat tst.awk
NR==1 { print; next }
!NF { next }
(++numLines) % 10 == 1 {
    printf "%s", maxLine
    maxVal = $5
    maxLine = ""
}
$5 >= maxVal {
    maxVal = $5
    maxLine = $0 ORS
}
END { printf "%s", maxLine }

$ awk -f tst.awk file
Name      No.           Value1   Value2   Determine
10_M62    6:            3.0561   405.69   1.1824
11_M63    2:            2.3544   526.62   1.8099

相關內容