我有一个问题。假设我转储一个文件并为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来实现这一目标?而不是逐行拉出数字并循环查找最大数字?
答案 0 :(得分:3)
awk的代码:
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