awk - 如何使用 awk 通过忽略带有字符的行来找到字段的最大值?

标签 awk

由于我是 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/

相关文章:

regex - 与 awk 一起使用的正则表达式中的量词表现出意外

awk - 使用该列的最大值标准化列数据

shell - 使用 SED、TR 或/和 awk 删除不需要的字符和空行

bash - 将文件内容与命令输出进行比较,然后执行命令并追加文件

arrays - 如何将文件拆分为数组并找到每个数组中的最大值

linux - awk 匹配一行中的多个正则表达式字符串和数字

awk - 如何将文本文件中的每一行另存为新文件

bash - 如何防止 awk 将换行符附加到匹配项

regex - 当新行在数据中时计算txt文件中的行数

linux - 如何从 bash 中的 .csv 文件的第一行获取特定列?