由于我是 awk
的新手,请帮助我提供您的建议。我尝试使用以下命令来过滤最大值并分别忽略示例文本文件中的第一行和最后一行。当我单独尝试它们时,它们就起作用了。
我的查询:
我需要忽略文件中的最后一行和前几行,然后需要使用 awk 获取字段 7 的最大值。
我还需要忽略带有字符的行。谁能建议我两个同时使用这两个命令并获得所需输出的可能性。
示例文件:
Linux 3.10.0-957.5.1.el7.x86_64 (j051s784) 11/24/2020 _x86_64_ (8 CPU)
12:00:02 AM kbmemfree kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty
12:10:01 AM 4430568 61359128 93.27 1271144 27094976 66771548 33.04 39005492 16343196 1348
12:20:01 AM 4423380 61366316 93.28 1271416 27102292 66769396 33.04 39012312 16344668 1152
12:30:04 AM 4406324 61383372 93.30 1271700 27108332 66821724 33.06 39028320 16343668 2084
12:40:01 AM 4404100 61385596 93.31 1271940 27107724 66799412 33.05 39031244 16344532 1044
06:30:04 PM kbmemfree kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty
07:20:01 PM 3754904 62034792 94.29 1306112 27555948 66658632 32.98 39532204 16476848 2156
Average: 4013043 61776653 93.90 1293268 27368986 66755606 33.03 39329729 16427160 2005
使用的命令:
cat testfile | awk '{print $7}' | head -n -1 | tail -n+7
awk 'BEGIN{a= 0}{if ($7>0+a) a=$7} END{print a}' testfile
预期输出:
Maximum value for the column 7 by excluding the lines wherever alphabet character is available
最佳答案
第一个解决方案(通用解决方案):在此处添加一个通用解决方案,其中将字段名称发送到 awk
变量(我们想要寻找最大值)它将自动从第一行找出其字段编号并相应地工作。考虑到您的第一行具有您想要查找的字段名称。
awk -v var="kbcached" '
FNR==1{
for(i=1;i<=NF;i++){
if($i==var){ field=i }
}
next
}
/kbmemused/{
next
}
{
if($2!~/^[AP]M$/){
val=$(field-1)
}
else{
val=$field
}
}
{
max=(max>val?max:val)
val=""
}
END{
print "Maximum value is:" max
}
' Input_file
第二个解决方案(仅根据显示的示例):您能否仅根据您显示的示例尝试以下操作。我假设您想要列 kbcached
的字段值。
awk '
/kbmemfree/{
next
}
{
if($2!~/^[AP]M$/){
val=$6
}
else{
val=$7
}
}
{
max=(max>val?max:val)
val=""
}
END{
print "Maximum value is:" max
}
' Input_file
关于awk - 如何使用 awk 通过忽略带有字符的行来找到字段的最大值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65005267/