如何使用AWK打印最高编号的行?

时间:2013-07-24 21:04:48

标签: linux sed awk

我有一个问题。假设我转储一个文件并为foo做一个grep,结果如下:

Foo-bar-120:'foo name 1'
Foo-bar-130:'foo name 2'
Foo-bar-1222:'foo name 3'

我想要的只是尝试提取最大数字的foo名称。例如,在这种情况下,最大数字是1222,我期望的结果是foo name 3

有没有一种简单的方法使用awk和sed来实现这一目标?而不是逐行拉出数字并循环查找最大数字?

6 个答案:

答案 0 :(得分:3)

的代码:

awk -F[-:] '$3>a {a=$3; b=$4} END {print b}' file

$ cat file
Foo-bar-120:'foo name 1'
Foo-bar-130:'foo name 2'
Foo-bar-1222:'foo name 3'

$ awk -F[-:] '$3>a {a=$3; b=$4} END {print b}' file
'foo name 3'

答案 1 :(得分:1)

假设行格式如“数字”之前的2个连字符所示:

cut -d- -f3- | sort -rn | sed '1{s/^[0-9]\+://; q}'

答案 2 :(得分:1)

这对你好吗?

awk -F'[:-]' '{n=$(NF-1);if(n>m){v=$NF;m=n}}END{print v}'

包含您的数据:

kent$  echo "Foo-bar-120:’foo name 1’
Foo-bar-130:’foo name 2’
Foo-bar-1222:’foo name 3’"|awk -F'[:-]' '{n=$(NF-1);if(n>m){v=$NF;m=n}}END{print v}'
’foo name 3’

P.S。我喜欢字段分隔符[:-]

答案 3 :(得分:1)

这是我将如何做到的。我刚在Cygwin测试过这个。希望它也可以在Linux下运行。将其放入文件中,例如mycommand

#!/usr/bin/awk -f

BEGIN {
        FS="-";
        max = 0;
        maxString = "";
}

{
        num = $3 + 0; # convert string to int
        if (num > max) {
                max = num;
                split($3, arr, "'");
                maxString = arr[2];
        }
}

END {
        print maxString;
}

然后使文件可执行(chmod 755 mycommand)。现在,您可以通过键入cat somefile | ./mycommand

来管理您想要的任何内容

答案 4 :(得分:1)

$ awk '{gsub(/.*:.|.$/,"")} (NR==1)||($NF>max){max=$NF; val=$0} END{print val}' file
foo name 3

答案 5 :(得分:0)

您无需使用grep。您可以直接在文件中使用awk

awk -F"[-:]" '/Foo/ && $3>prev{val=$NF;prev=$3}END{print val}' file