awk print column $3 if $2==a specific value?
我正在从awk编程语言中学习awk,并被这个例子所困扰。
如果我想打印$ 3如果$ 2等于一个值(例如'1'),我正在使用这个命令工作正常:
1 | awk '$2==1 {print $3}' <infile> | more |
但是当我用另一个搜索条件替换1时,例如'findtext',这个命令不起作用。
1 | awk '$1== findtext {print $3}' <infile> | more |
这没有返回任何输出,我确定我放在'findtext'中的内容存在于那个地方。
我的语法有什么问题吗?
我试过这个,但它不起作用:
1 | awk '$1=="findtext" {print $3}' <infile> | more |
但是,当我这样做
1 | grep findtext <infile> ## This does give me output |
在我仔细检查时,findtext存在于$ 1中。
这是我的测试文件名为'test',例如,它有9行,8个字段和空格分隔:
1 2 3 4 5 6 7 8 9 | 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 |
这是我做的和输出:
1 2 3 4 5 6 | $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美元。
1 2 3 | 0.180467091 0.010615711 0.492569002 |
不知道为什么awk命令没有返回任何东西。 有什么想法吗?
如果您正在寻找特定字符串,请在其周围加上引号:
1 | awk '$1 =="findtext" {print $3}' |
否则,awk会认为它是变量名。
这个方法使用regexp,它应该工作:
1 | awk '$2 ~ /findtext/ {print $3}' <infile> |
根据
你试过
1 | awk '$1 ~ /^hello$/{ print $3; }' <infile> |
这对我来说更具可读性
1 | awk '{if ($2 ~ /findtext/) print $3}' <infile> |
我的awk版本是3.1.5。
是的,输入文件是空格分隔的,没有标签。
根据arutaku的回答,这是我尝试过的工作:
1 2 3 4 5 6 7 8 9 10 | 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版本:),
1 2 | $awk '$8 ~"^ClNonZ$"{ print $3; }' test $awk '$8 =="ClNonZ" { print $3 }' test |
谢谢大家的回答,评论和帮助!
请试试这个
1 | echo $VAR | grep ClNonZ | awk '{print $3}'; |
要么
1 | echo cat filename | grep ClNonZ | awk '{print $3}'; |