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

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

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

等等.

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

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

最佳答案
这是我将如何做到这一点.我刚在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.

转载注明原文:linux – 如何使用AWK打印最高编号的行? - 代码日志