如何从管道和文件中输入awk输入?

时间:2015-10-15 00:19:19

标签: linux awk

我想知道如何让awk从管道输出和文件中取出一个字符串?

我基本上有一系列命令,最终会吐出一个字符串。我想针对csv文件检查此字符串(以逗号分隔的列)。然后,我想找到文件中包含csv文件第7列中字符串的第一行,并打印出该行第5列的内容。另外,我不太了解linux命令行实用程序/ awk,所以随意提出完全不同的方法。 :)

CSV文件内容如下所示:

col1,col2,col3,col4,col5,etc...
col1,col2,col3,col4,col5,etc...
etc...

我的一般思路:

(rest of commands that will give a string) | awk -F ',' 'if($5 == string){print $7;exit}' filename.txt

可以这样做吗?如果是这样,我如何告诉awk与该字符串进行比较? 我发现了一些关于在文件名之前使用-符号和ARGV[]的内容,但无法使其正常工作。

1 个答案:

答案 0 :(得分:7)

正如Karoly所说,

str=$( rest of commands that will give a string )
awk -v s="$str" -F, '$7==s {print $5; exit}' file

如果你想用管道输入awk:

cmds | awk -F, 'NR==FNR {str=$0; next}; $7==str {print $5}' - file

我认为第一种选择更具可读性。