使用具有列值条件的 awk

我从 AWK 编程语言中学到了一些东西,我在其中一个例子中遇到了问题。

如果我想在 $2等于一个值的情况下输出 $3(例如 1) ,我使用了这个命令,它工作得很好:

awk '$2==1 {print $3}' <infile> | more

但是当我用另一个搜索条件(例如 findtext)替换1时,命令就不起作用了:

awk '$1== findtext {print $3}' <infile> | more

它不返回任何输出,我确信输入文件中存在“ findtext”。

我也试过这种方法,但不管用:

awk '$1== "findtext" {print $3}' <infile> | more

下面是我的名为‘ test’的测试文件,它有9行和8个字段,用空格分隔:

1 11 0.959660297 0 0.021231423 -0.0073 -0.0031 MhZisp
2 14 0.180467091 0.800424628 0 0.0566 0.0103 ClNonZ
3 19 0.98089172 0 0 -0.0158 0.0124 MhNonZ
4 15 0.704883227 0.265392781 0.010615711 -0.0087 -0.0092 MhZisp
5 22 0.010615711 0.959660297 0.010615711 0.0476 0.0061 ClNonZ
6 23 0.715498938 0 0.265392781 -0.0013 -0.0309 Unkn
7 26 0.927813163 0 0.053078556 -0.0051 -0.0636 MhZisp
8 44 0.55626327 0.222929936 0.201698514 0.0053 -0.0438 MhZisp
9 31 0.492569002 0.350318471 0.138004246 0.0485 0.0088 ClNonZ

下面是我所做的和输出:

$awk '$8 == "ClNonZ" {print $3}' test


$ grep ClNonZ test
2 14 0.180467091 0.800424628 0 0.0566 0.0103 ClNonZ
5 22 0.010615711 0.959660297 0.010615711 0.0476 0.0061 ClNonZ
9 31 0.492569002 0.350318471 0.138004246 0.0485 0.0088 ClNonZ

我希望看到这是3美元,有“ ClNonZ”在他们的8美元。

0.180467091
0.010615711
0.492569002

不知道为什么 awk 命令没有返回任何东西,有什么想法吗?

344178 次浏览

如果你正在寻找一个特定的字符串,在它周围加上引号:

awk '$1 == "findtext" {print $3}'

否则,awk 将假定它是一个变量名。

取决于 AWK的实现是否使用 ==是可以的。

你试过 ~吗? 例如,如果你想用1美元代表“你好”:

awk '$1 ~ /^hello$/{ print $3; }' <infile>

^表示1美元起始,$表示1美元结束。

我的 awk 版本是3.1.5。

是的,输入文件是空格分隔的,没有制表符。

根据 arutaku 的回答,以下是我的成功尝试:

awk '$8 ~ "ClNonZ"{ print $3; }' test
0.180467091
0.010615711
0.492569002




$ awk '$8 ~ "ClNonZ" { print $3}' test
0.180467091
0.010615711
0.492569002

什么不起作用(我不知道为什么,也许是因为我的 awk 版本:) ,

$awk '$8 ~ "^ClNonZ$"{ print $3; }' test
$awk '$8 == "ClNonZ" { print $3 }' test

谢谢你们的回答,评论和帮助!

请尝尝这个

echo $VAR | grep ClNonZ | awk '{print $3}';

或者

echo cat filename | grep ClNonZ | awk '{print $3}';

这个方法使用 regexp,它应该可以工作:

awk '$2 ~ /findtext/ {print $3}' <infile>

这对我来说更容易理解

awk '{if ($2 ~ /findtext/) print $3}' <infile>