一尘不染

在列值条件下使用awk

linux

我正在从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

我希望看到这是在其$ 8中有“ ClNonZ”的$ 3。

0.180467091 
0.010615711 
0.492569002

不知道为什么awk命令没有返回任何内容。有什么想法吗?


阅读 227

收藏
2020-06-02

共1个答案

一尘不染

如果您要查找特定的字符串,请在其周围加上引号:

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

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

2020-06-02