查找特定列中每 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

相关内容