awk打印列$ 3如果$ 2 ==具体值?

use*_*130 101 linux shell awk

我正在从awk编程语言中学习awk,并被这个例子所困扰.

如果我想打印$ 3,如果$ 2等于一个值(例如'1'),我正在使用这个命令工作正常:

awk '$2==1 {print $3}' <infile> | more
Run Code Online (Sandbox Code Playgroud)

但是当我用另一个搜索条件替换1时,例如'findtext',这个命令不起作用.

awk '$1== findtext {print $3}' <infile> | more
Run Code Online (Sandbox Code Playgroud)

这没有返回任何输出,我确定我放在'findtext'中的内容存在于那个地方.我的语法有什么问题吗?

我试过这个,但它不起作用:

awk '$1== "findtext" {print $3}' <infile> | more
Run Code Online (Sandbox Code Playgroud)

但是,当我这样做

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
Run Code Online (Sandbox Code Playgroud)

在我仔细检查时,findtext存在于$ 1中.

这是我的测试文件名为'test',例如,它有9行,8个字段和空格分隔:

$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
Run Code Online (Sandbox Code Playgroud)

这是我做的和输出:

0.180467091 
0.010615711 
0.492569002
Run Code Online (Sandbox Code Playgroud)

我希望看到这是在他们的8美元中拥有"ClNonZ"的3美元.

awk '$2==1 {print $3}' <infile> | more
Run Code Online (Sandbox Code Playgroud)

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

Rob*_*vis 115

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

awk '$1 == "findtext" {print $3}'
Run Code Online (Sandbox Code Playgroud)

否则,awk会认为它是变量名.


Ell*_*Ell 29

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

awk '$2 ~ /findtext/ {print $3}' <infile>
Run Code Online (Sandbox Code Playgroud)


aru*_*aku 18

根据AWK实施情况,您使用==的确定与否.

你试过~吗?例如,如果您希望$ 1为"hello":

awk '$1 ~ /^hello$/{ print $3; }' <infile>
Run Code Online (Sandbox Code Playgroud)

^意味着$ 1开始,并且$是$ 1结束.

  • 所有awk实现都支持"=="和"〜". (3认同)
  • @EdMorton-OS X的“ awk”未能与“ ==”匹配,但获得了“〜”成功。 (2认同)
  • @jww与什么不匹配?这些是等价的:`$ 1 =="hello"`和`$ 1~/^ hello $ /`.你应该永远不要做`$ 1~"^ hello $"`,因为它在正则表达式上下文中使用了一个字符串,所以awk必须在使用之前将字符串转换为regexp并且有副作用(man awk) ). (2认同)

use*_*013 9

这对我来说更具可读性

awk '{if ($2 ~ /findtext/) print $3}' <infile>
Run Code Online (Sandbox Code Playgroud)